MySQL主从复制不一致,如何预防及解决?
一、导致主从不一致的原因主要有:
- 人为原因导致从库与主库数据不一致(从库写入)
- 主从复制过程中,主库异常宕机
- 设置了ignore/do/rewrite等replication等规则
- binlog非row格式
- 异步复制本身不保证,半同步存在提交读的问题,增强半同步起来比较完美。 但对于异常重启(Replication Crash Safe),从库写数据(GTID)的防范,还
- 需要策略来保证。
- 从库中断很久,binlog应用不连续,监控并及时修复主从
- 从库启用了诸如存储过程,从库禁用存储过程等
- 数据库大小版本/分支版本导致数据不一致?,主从版本统一
- 备份的时候没有指定参数 例如mysqldump --master-data=2 等
- 主从sql_mode 不一致
- 一主二从环境,二从的server id一致
- MySQL自增列 主从不一致
- 主从信息保存在文件里面,文件本身的刷新是非事务的,导致从库重启后开始执行点大于实际执行点
- 采用5.6的after_commit方式半同步,主库当机可能会引起主从不一致,要看binlog是否传到了从库
- 启用增强半同步了(5.7的after_sync方式),但是从库延迟超时自动切换成异步复制
二、预防和解决的方案有:
- master:innodb_flush_log_at_trx_commit=1&sync_binlog=1
- slave:master_info_repository="TABLE"&relay_log_info_repository="TABLE"&relay_log_recovery=1
- 设置从库库为只读模式
- 可以使用5.7增强半同步避免数据丢失等
- binlog row格式
- 必须引定期的数据校验机制
- 当使用延迟复制的时候,此时主从数据也是不一致的(计划内),但在切换中,不要把延迟从提升为主库哦~
![](https://cdn.jsdelivr.net/gh/Carry00/images/2021/02/06/20210206030215051.jpg)
posted @
2019-01-21 14:03
Carry00
阅读(
1826)
评论()
编辑
收藏
举报