背景
之前搭建了主从,但没有设置读写分离,从库也能写数据。于是想测试下在从库写数据会导致同步怎么样。 结果发现,slave_sql_running为no,slava_IO_running仍然为yes.
原因
由于从库写数据,导致主从数据不一致,如果在主库写入和从库同样的数据,会导致sql线程终止,查看mysql错误日志如下
解决方法 在从库停掉slave同步,执行 stop slave; 主库执行 SHOW MASTER STATUS,记录下File和Position的值 从库根据主库的position位置重新连接进行同步 CHANGE MASTER TO master_host = '192.168.164.84', MASTER_PORT = 3306, master_user = 'root', master_password = 'root', master_log_file = 'mysql-bin.000001', master_log_pos = 902262;#这里记录master最新的position 从库启动同步, start slave; 通过以上步骤,可以实现主从重新开始同步。 在从库执行以下命令: stop slave; set GLOBAL SQL_SLAVE_SKIP_COUNTER=1; start slave; SHOW SLAVE STATUS
个人体会 用解决方法一存在一个问题。比如在从库写入一条数据11, 在主库写入一条数据12,我们知道由于主从不同步会导致slave_sql_running停了。如果通过第一种方法重新连接启动后,再把12这条数据删除,会报以下错误: 从库由于找不到12这条记录进行删除从而会终止slave_sql_running这个线程,需要再重新连接主库的binlog最新位置进行同步。
总结 这里列出了主从不同步两种解决方案,测试发现第二种解决方案好一些. 其实按道理一般不会出现主从不同步的情况,因为主从需要搭配读写分离来弄。从库既然只能读,那就不存在主从不同步的情况了。 |