优化Mysql主从同步延时现象 【优化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即可
推荐阅读
- mysql|InnoDB数据页结构
- javaweb|基于Servlet+jsp+mysql开发javaWeb学生成绩管理系统
- mysql|一文深入理解mysql
- Java毕业设计项目实战篇|Java项目:在线嘿嘿网盘系统设计和实现(java+Springboot+ssm+mysql+maven)
- SQL|SQL基本功(五)--函数、谓词、CASE表达式
- vue|电商后台管理系统(vue+python|node.js)
- Java及基础算法及数据结构|旧笔记整理(MySQL)
- mysql|双非本211硕,无实习无项目,自学大数据开发,秋招上岸
- 数据库|Mysql--InnoDB存储引擎详解
- MySQL学习笔记-9-order by