• 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. 主从信息保存在文件里面,文件本身的刷新是非事务的,导致从库重启后开始执行点大于实际执行点

    14. 采用5.6的after_commit方式半同步,主库当机可能会引起主从不一致,要看binlog是否传到了从库

    15. 启用增强半同步了(5.7的after_sync方式),但是从库延迟超时自动切换成异步复制

    二、预防和解决的方案有:
    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、必须引定期的数据校验机制

    7、当使用延迟复制的时候,此时主从数据也是不一致的(计划内),但在切换中,不要把延迟从提升为主库哦~

    8、mha在主从切换的过程中,因主库系统宕机,可能造成主从不一致(mha本身机制导致这个问题)

  • 相关阅读:
    ArcGIS API for JavaScript 学习笔记 (一) --第一个WebGIS应用程序
    C#学习之数据类型-(一:简介)
    用vs发布网站,IIS部署浏览网站的具体步骤。
    载入内存,让程序运转起来。
    placeholder的使用
    京东商城注册页使用的正则表达式(转)
    网站列表页竖直栏目图片灰色背景导航菜单代码
    CSS定义鼠标悬浮,图片出现边框
    生成虚线代码(小白自留)
    划过或点击下面带框的文本
  • 原文地址:https://www.cnblogs.com/os-linux/p/11928996.html
Copyright © 2020-2023  润新知