MySQL中主从延迟高,怎么解决?
Posted handsomeboy-东
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL中主从延迟高,怎么解决?相关的知识,希望对你有一定的参考价值。
主从同步的延迟的原因:
我们知道, 一个服务器开放N个链接给客户端来连接的,这样有会有大并发的更新操作, 从服务器通过I/O的线程去主服务器同步二进制日志,当某个SQL在从服务器上执行的时间稍长 或者由于某个SQL要进行锁表就会导致主服务器的SQL大量积压,未被同步到从服务器里。这就导致了主从不一致,也就是主从延迟。
主从同步延迟的解决办法:
软件方面:
因为所有的SQL必须都要在从服务器里面执行一遍,但是主服务器如果不断的有更新操作源源不断的写入,那么一旦有延迟产生,那么延迟加重的可能性就会原来越大。 当然我们可以做一些缓解的措施。
a. 我们知道因为主服务器要负责更新操作, 他对安全性的要求比从服务器高, 所有有些设置可以修改,比如sync_binlog=1,innodb_flush_log_at_trx_commit = 1 之类的设置,而slave则不需要这么高的数据安全,完全可以将sync_binlog设置为0或者关闭binlog,innodb_flushlog,innodb_flush_log_at_trx_commit 也可以设置为0来提高sql的执行效率 这个能很大程度上提高效率。另外就是使用比主库更好的硬件设备作为slave。
b. 就是把一台从服务器当作为备份使用,而不提供查询,那边他的负载下来了,执行relay log 里面的SQL效率自然就高了。
硬件方面:
1.主或者从服务器负载过高,给服务器扩容;
2.增加从服务器,这个目的还是分散读的压力, 从而降低服务器负载。
3.判断主从延迟的方法
可以通过 show slave status 进行查看,比如可以看看Seconds_Behind_Master参数的值来判断,是否有发生主从延时。
其值有这么几种:
NULL - 表示io_thread或是sql_thread有任何一个发生故障,也就是该线程的Running状态是No,而非Yes.
0 - 该值为零,是我们极为渴望看到的情况,表示主从复制状态正常
以上是关于MySQL中主从延迟高,怎么解决?的主要内容,如果未能解决你的问题,请参考以下文章