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

你可能感兴趣的:(mysql)