本文共 684 字,大约阅读时间需要 2 分钟。
今天继续讨论,MySQL主从复制什么原因会造成不一致,如何预防及解决? 1.人为原因导致从库与主库数据不一致(从库写入) 2.主从复制过程中,主库异常宕机 3.设置了ignore/do/rewrite等replication等规则 4.binlog非row格式 5.异步复制本身不保证,半同步存在提交读的问题,增强半同步起来比较完美。 但对于异常重启(Replication Crash Safe),从库写数据(GTID)的防范,还需要策略来保证。 6.从库中断很久,binlog应用不连续,监控并及时修复主从 7.从库启用了诸如存储过程,从库禁用存储过程等 8.数据库大小版本/分支版本导致数据不一致?,主从版本统一 9.备份的时候没有指定参数 例如mysqldump --master-data=2 等 10.主从sql_mode 不一致 11.一主二从环境,二从的server id一致。 12.MySQL自增列 主从不一致 13.主从信息保存在文件里面,文件本身的刷新是非事务的,导致从库重启后开始执行点大于实际执行点 预防措施: 1.master:innodb_flush_log_at_trx_commit=1&sync_binlog=1 2.slave:master_info_repository="TABLE"&relay_log_info_repository="TABLE"&relay_log_recovery=1 3.设置从库库为只读模式 4.可以使用5.7增强半同步避免数据丢失等 5.binlog row格式 6.必须引定期的数据校验机制转载地址:http://fwtsi.baihongyu.com/