您的位置:首页 > 数据库 > MySQL

优化Mysql主从同步延时现象

2017-10-11 21:54 267 查看

优化Mysql主从同步延时现象

本方案适用于使用了读写分离,且要求数据强一致性的场景。这里未提及 解决 字眼,是因为Mysql主从同步使用异步复制方案时,延时是个客观存在的现象,无法根绝,当然愿意全同步的,另当别论。

这里使用 Mysql无损半同步 以及 多线程同步 来尽可能的缩短这一时延。

环境依赖

Mysql 5.7 及以上。

虽然半同步仅要求5.5及以上,但是多线程同步是5.7版本才开始支持的。

Mysql需已配置完成异步同步

开启半同步

确认变量
have_dynamic_loading
为YES,否则修改为YES

修改my.cnf配置的mysqld段,添加如下配置。(我这边是互为主从的场景,所以每个节点都开启主从半同步)

plugin-load = "rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so"
rpl-semi-sync-master-enabled = 1
rpl-semi-sync-slave-enabled = 1


开启多线程同步

修改my.cnf配置的mysqld段,添加如下配置。

在每个mysql节点开启多线程同步,线程数根据实际项目需要进行调整。

如下配置可以在200+读写并发的情况下保证每个节点读取数据的一致性。

slave-parallel-type=LOGICAL_CLOCK
slave-parallel-workers=8


配置完成后重启mysql即可

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: