手把手教你MySQL主从复制,配置不成功你找我!(三)

我们先在从库的数据库中生成一个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';



上一篇:小技巧 | 如何在SQL Server中快速创建测试数据?


下一篇:巧用spt_values解决SQL中的连续日期问题