mysql主从延迟怎么办 mysql主从延迟原因( 三 )


怎样解决MySQL数据库主从复制延迟的问题怎样解决MySQL数据库主从复制延迟的问题
可以通过监控show slave status\G命令输出的Seconds_Behind_Master参数的值来判断mysql主从延迟怎么办,是否有发生主从延时 。
其值有这么几种:
NULL - 表示io_thread或是sql_thread有任何一个发生故障mysql主从延迟怎么办 , 也就是该线程的Running状态是No,而非Yes.
0 - 该值为零mysql主从延迟怎么办,是我们极为渴望看到的情况 , 表示主从复制良好,可以认为lag不存在 。
正值 - 表示主从已经出现延时,数字越大表示从库落后主库越多 。
负值 - 几乎很少见,只是听一些资深的DBA说见过,其实 , 这是一个BUG值,该参数是不支持负值的,也就是不应该出现 。
数据包延时问题?谈到MySQL数据库主从同步延迟原理,得从mysql的数据库主从复制原理说起 , mysql的主从复制都是单线程的操作 , 主库对所有DDL和 DML产生binlog,binlog是顺序写 , 所以效率很高,slave的Slave_IO_Running线程到主库取日志,效率很比较高 , 下一步, 问题来了,slave的Slave_SQL_Running线程将主库的DDL和DML操作在slave实施 。DML和DDL的IO操作是随即的,不是顺 序的,成本高很多,还可能可slave上的其他查询产生lock争用,由于Slave_SQL_Running也是单线程的 , 所以一个DDL卡主了,需要 执行10分钟 , 那么所有之后的DDL会等待这个DDL执行完才会继续执行,这就导致了延时 。有朋友会问:“主库上那个相同的DDL也需要执行10分,为什 么slave会延时?” , 答案是master可以并发,Slave_SQL_Running线程却不可以 。
2. MySQL数据库主从同步延迟是怎么产生的 。
答:当主库的TPS并发较高时 , 产生的DDL数量超过slave一个sql线程所能承受的范围 , 那么延时就产生了,当然还有就是可能与slave的大型query语句产生了锁等待 。
3. MySQL数据库主从同步延迟解决方案
答:最简单的减少slave同步延时的方案就是在架构上做优化,尽量让主库的DDL快速执行 。还有就是主库是写,对数据安全性较高,比如 sync_binlog=1,innodb_flush_log_at_trx_commit = 1 之类的设置,而slave则不需要这么高的数据安全 , 完全可以讲sync_binlog设置为0或者关闭binlog,innodb_flushlog也 可以设置为0来提高sql的执行效率 。另外就是使用比主库更好的硬件设备作为slave 。
mysql-5.6.3已经支持了多线程的主从复制 。原理和丁奇的类似,丁奇的是以表做多线程 , Oracle使用的是以数据库(schema)为单位做多线程,不同的库可以使用不同的复制线程 。
基于局域网的master/slave机制在通常情况下已经可以满足'实时'备份的要求了 。如果延迟比较大,就先确认以下几个因素:
网络延迟
master负载
slave负载
一般的做法是 , 使用多台slave来分摊读请求,再从这些slave中取一台专用的服务器,只作为备份用,不进行其他任何操作,就能相对最大限度地达到'实时'的要求了
slave_net_timeout单位为秒 默认设置为 3600秒 参数含义:当slave从主数据库读取log数据失败后,等待多久重新建立连接并获取数据 master-connect-retry单位为秒 默认设置为 60秒 参数含义:当重新建立主从连接时 , 如果连接建立失败 , 间隔多久后重试 。
通常配置以上2个参数可以减少网络问题导致的主从数据同步延迟
MySQL主从延迟Seconds_Behind_Master计算方式这样计算的问题mysql主从延迟怎么办:
1、 首先这样的计算方法本身是不对的mysql主从延迟怎么办,如果本地时间有问题会导致event时间戳不准,从而出现误差,所以计算公式中会记录一下主从库的当前时间差

推荐阅读