优化Mysql主从同步延时现象

优化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即可

    推荐阅读