• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL主从延迟现象及原理分析详解

    一、现象

    凌晨对线上一张表添加索引,表数据量太大(1亿+数据,数据量50G以上),造成主从延迟几个小时,各个依赖从库的系统无法查询数据,最终影响业务。

    现在就梳理下主从延迟的原理。

    二、原理

    根据 MySQL 官方文档 MySQL Replication Implementation Details 中的描述,MySQL 主从复制依赖于三个线程:master一个线程(Binlog dump thread),slave两个线程(I/O threadSQL thread)。主从复制流程如下图:

    master 服务器和 slave 服务器连接时,创建Binlog dump thread以发送bin log数据:

    当 slave 服务器收到 START_SLAVE 命令时,会创建I/O threadSQL thread

    注: START_SLAVE命令成功启动线程后,如果后面I/O threadSQL thread因为某些原因停止,则不会有任何的警告,业务方无法感知。可以通过查看 slave 的 error 日志,或者通过 SHOW SLAVE STATUS 查看 slave 上的线程状态。

    通过 SHOW PROCESSLIST 可查看线程状态:

    Binlog dump thread:

    mysql> SHOW PROCESSLIST\G
    *************************** 1. row ***************************
      Id: 2
     User: root
     Host: localhost:32931
      db: NULL
    Command: Binlog Dump
     Time: 94
     State: Has sent all binlog to slave; waiting for binlog to
       be updated
     Info: NULL

    I/O thread 和 SQL thread:

    mysql> SHOW PROCESSLIST\G
    *************************** 1. row ***************************
      Id: 10
     User: system user
     Host:
      db: NULL
    Command: Connect
     Time: 11
     State: Waiting for master to send event
     Info: NULL
     *************************** 2. row ***************************
      Id: 11
     User: system user
     Host:
      db: NULL
    Command: Connect
     Time: 11
     State: Has read all relay log; waiting for the slave I/O
       thread to update it
     Info: NULL

    三、分析

    根据上面的原理,由于slave是单线程(I/O thread)读取数据,单线程(SQL thread)更新数据,而master是多线程写入,那么只要master写入的频率大于slave读取更新的频率,就有可能出现主从延迟的情况,如:

    1. master写入tps较高,大于slave更新速度;
    2. slave执行某些语句耗时较长,如持有锁等;
    3. master执行某些DDL语句时,执行的时间较长,在slave也执行相同的时间;

    此处创建了索引,咨询 DBA,产生的bin log文件有100多G,数据量太大,导致从库I/O thread一直读取DDL操作产生的bin log事件,而影响到正常的业务DML事件的更新,从而表现为主从同步延迟。

    四、解决方案

    从主从延迟的原因来看,解决方案可以从以下几个方向入手:

    1. 业务选型,对于无法忍受从库延迟的架构,可选择分布式架构等,避开从库延迟问题
    2. 执行时间,对大表进行线上DDL操作尽量选择凌晨等业务量较小的时候
    3. 硬件配置,升级从库硬件配置,如SSD
    4. 减少请求,增加缓存层,减少读请求落库

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

    您可能感兴趣的文章:
    • MySQL主从复制延迟原因以及解决方案
    • MySQL5.6升级5.7时出现主从延迟问题排查过程
    • MySQL主从同步延迟的原因及解决办法
    • MYSQL主从不同步延迟原理分析及解决方案
    • 减少mysql主从数据同步延迟问题的详解
    • 深入mysql主从复制延迟问题的详解
    • MySQL主从延迟问题解决
    上一篇:mysql 8.0.13手动安装教程
    下一篇:MySQL 8忘记密码的最佳处理方式浅析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL主从延迟现象及原理分析详解 MySQL,主从,延迟,现象,及,