优化Mysql主从同步延时现象

优化Mysql主从同步延时现象

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

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

环境依赖

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

  2. 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即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值