我们先在从库的数据库中生成一个UUID
mysql>select UUID();
将数据库中查询出来的这个UUID复制出来,然后编辑从库的UUID配置文件
如果你也安装的跟我一样,那么这个配置文件的路径就应该在这里:
[root@localhost ~]# vi /usr/local/mysql/data/auto.cnf
进去后,将一串32位长的UUID,替换成我们刚在数据库中查询生成的UUID即可。
如果Slave_IO_Running: No 并出现下面错误
Got fatal error 1236 from master when reading data from binary log: 'Could not find first log file name in binary log index file'
解决方法:复位
mysql>stop slave; //停止 mysql>reset slave; //复位 mysql>start slave; //开启
至此整个过程就配置好了。
可能有小伙伴会问,这些配置文件我都配好了,信息也和你的一样,我还是不确定是否配置成功。
那么你可以在主服务器上创建一个表,然后在从服务器上查询刚创建的这个表,看是否存在就可以啦。
Tips
1、关于增删改查,主从数据不一致问题:
#select 语句,暂时没有发现问题 #insert 语句,暂时没有发现问题 #update 语句,暂时没有发现问题 #delete 语句,主库删除多条数据,发现数据不一致
原因:在主库的logbin中的确有执行删除语句,但是在从库的logbin中却没有删除语句解决:使用 use database 选取当前数据库架构中的需要操作的数据库,然后在执行删除,OK同步成功
2、查询binlog主从日志的方法
#查看binlog全部文件 mysql>show binary logs; #查看binlog是否开启NO为开启 mysql> show variables like 'log_bin%'; #详细信息 mysql> show variables like 'binlog%'; #查看binlog日志 mysql> show binlog events in'mysql-bin.000019'; #或者使用mysqlbinlog,如果报错使用--no-defaults(使用全路径) [root@localhost ~]# /usr/local/mysql/bin/mysqlbinlog --no-defaults /usr/local/mysql/data/mysql-bin.000019
3、手动清理master日志,最好关闭日志,在/etc/my.cnf
#手动刷新日志 mysql> show master status; #删除全部 mysql> reset slave;或 rest master; #删除MySQL-bin.004 mysql> PURGE MASTER LOGS TO 'MySQL-bin.004';