测量从数据库延迟的方法有

测量从数据库延迟的方法有,第1张

主从延时排查方法:

第一种方法:

1.showmasterstatus\G#查看主库的position号记录到多少了。

2.从库中执行showslavestatus\G#查看从库现在获取到哪个position号了.

3.如果从库的postion号远小于主库的position号,则表示主库dump线程传送二进制出问题了.

第二种方法(推荐):

通过监控showslavestatus命令输出的“Seconds_Behind_Master”参数的值来判断NULL,表示io_thread或是sql_thread有任何一个发生故障;

0,该值为零,表示主从复制良好;正值,表示主从已经出现延时,数字越大表示从库延迟越严重。为了再现这种高并发时刻,测试指令为:ab-c12-n10000http://tp5pro.com/index/test。

谈到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个参数可以减少网络问题导致的主从数据同步延迟

高速稳定的SSD我还真有一个可以推荐的,我朋友公司用的是宝存科技的SP4 Series NVMe SSD,传输速度和稳定性能都在线。这个系列固态硬盘通过主控升级并充分利用NAND的特性,最大稳态延迟已经控制在10ms以下⌄能够为各种企业级IO负载提供优异稳态下的QoS表现,朋友说它内部建了16条闪存通道,读顺序读取和写入速度嗖嗖快,4K随机读取速度高达900K IPS,4K稳态写入高达180K IOP,这简直是公司存储的一大利器。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9252382.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-26
下一篇2023-04-26

发表评论

登录后才能评论

评论列表(0条)

    保存