服务好的网站开发,怎么制作小程序软件,网站展示程序,惠州市seo上词背景之前搭建了主从#xff0c;但没有设置读写分离#xff0c;从库也能写数据。于是想测试下在从库写数据会导致同步怎么样。 结果发现#xff0c;slave_sql_running为no#xff0c;slava_IO_running仍然为yes.原因由于从库写数据#xff0c;导致主从数据不一致#xff0…背景之前搭建了主从但没有设置读写分离从库也能写数据。于是想测试下在从库写数据会导致同步怎么样。 结果发现slave_sql_running为noslava_IO_running仍然为yes.原因由于从库写数据导致主从数据不一致如果在主库写入和从库同样的数据会导致sql线程终止查看mysql错误日志如下2020-08-01T10:58:19.623077Z 135 [ERROR] Slave SQL for channel : Could not execute Write_rows event on table shy_dep.zp_test; , Error_code: 1062; handler error HA_ERR_FOUND_DUPP_KEY; the events master log mysql-bin.000001, end_log_pos 882496, Error_code: 10622020-08-01T10:58:19.623101Z 135 [Warning] Slave: Error_code: 10622020-08-01T10:58:19.623110Z 135 [ERROR] Error running query, slave SQL thread aborted. Fix the problem, and restart the slave SQL thread with SLAVE START. We stopped at log mysql-bin.000001 position 882218解决方法一在从库停掉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;通过以上步骤可以实现主从重新开始同步。PS: 这里在重新启动从库同步时假设主库没有进行写操作。因为如果进行了写操作则刚才记录的主库position位置可能会变。所以一般需要把主库临时加锁不让写。解决方法二在从库执行以下命令stop slave;set GLOBAL SQL_SLAVE_SKIP_COUNTER1;start slave;SHOW SLAVE STATUS经测试以上方法也可以。个人体会用解决方法一存在一个问题。比如在从库写入一条数据11 在主库写入一条数据12我们知道由于主从不同步会导致slave_sql_running停了。如果通过第一种方法重新连接启动后再把12这条数据删除会报以下错误2020-08-01T11:00:38.853703Z 17564 [ERROR] Slave SQL for channel : Could not execute Delete_rows event on table shy_dep.zp_test; Unknown error 1032, Error_code: 1032; handler error HA_ERR_KEY_NOT_FOUND; the events master log mysql-bin.000001, end_log_pos 883098, Error_code: 10322020-08-01T11:00:38.853717Z 17564 [Warning] Slave: Unknown error 1032 Error_code: 10322020-08-01T11:00:38.853721Z 17564 [ERROR] Error running query, slave SQL thread aborted. Fix the problem, and restart the slave SQL thread with SLAVE START. We stopped at log mysql-bin.000001 position 882828从库由于找不到12这条记录进行删除从而会终止slave_sql_running这个线程需要再重新连接主库的binlog最新位置进行同步。而解决方法二即使删除了12这条记录仍然会保持同步。所以这里给我感觉是第二种方式要好一些。set global sql_slave_skip_counterN #这里的N是指跳过N个event官方解释This statement skips the next N events from the master. This is useful for recovering from replication stops caused by a statement.个人理解就是跳过当前从master中不能执行的事件总结这里列出了主从不同步两种解决方案测试发现第二种解决方案好一些.其实按道理一般不会出现主从不同步的情况因为主从需要搭配读写分离来弄。从库既然只能读那就不存在主从不同步的情况了。内容来源于网络如有侵权请私信删除