MySQL Slave异常关机的处理

2014-11-24 17:17:53 · 作者: · 浏览: 0

生产环境有一个MySQL的Master-Slave的复制。


前一阵子机房网络升级,但是考虑到一般网络故障恢复之后,只需要start slave即可


所以没有做任何的处理。


但是第二天上班的时候,在Slave数据库上输入命令,start slave 不能重新启动复制。


模拟环境如下



在Slave上启动复制,报错如下



复制过程出现主键重复了



最后,使用status查看,发现MySQL被重启过。


估计在割接过程中,莫名其妙的被人按了服务器的重启键吧。


但是MySQL复制针对这种情况,异常的脆弱,因为复制的信息都写在一个文件里,


考虑到性能的原因,这个写入并不是同步的。


也就是说在断电重启的瞬间,复制的情况并没有写入到文件中。


而再次启动之后,读取这个文件中记录的复制位置,肯定落后于实际执行的位置。


所以会发生主键重复的问题,因为这个记录实际已经执行过了。


解决这个问题有三种方式


1.设置sql_slave_skip_counter跳过Master发来的事件,直到正常的位置



启动之后,发现报错信息已经变了



他重复的主键已经从7940到了7946了,也就说通过一点一点的推进,是可以推进到正常的复制位置的。


但是工作量比较大,需要很有耐心和时间做这个事情。


2.设置slave_skip_errors


在my.cnf配置文件中设置slave_skip_errors=1062,跳过所有主键重复的错误。


但是这个参数设置之后,需要重启服务。对于生产系统来说,没有实际意义。


3.设置slave_exec_mode


MySQL默认的slave执行方式是严格的。


类似主键重复的问题,会直接停止复制,等待人工介入。


slave_exec_mode是一个动态参数,如果设置为IDEMPOTENT可以自动忽略主键重复和没有找到记录的错误。


但是貌似只是在MySQL集群环境有效


http://dev.mysql.com/doc/refman/5.6/en/replication-options-slave.html#sysvar_slave_exec_mode


异常断电和关机除了可能导致主键重复的错误之外,还可能导致中继日志损坏



针对这个问题,首先,找到master binlog执行的位置



位置



然后重新连接Master服务器,(需要先停止slave)



最后查看复制情况,已经正常。


这次的经验是,如果预计可能发生状况,比如这次网络割接,


可以先停止slave的服务器。因为我们的slave只是作为备份的一种方式,而不是用于读写分离。


或者干脆设置slave_skip_errors参数。



--------------------------------------分割线 --------------------------------------


--------------------------------------分割线 --------------------------------------