MySQL 5.7增强版Semisync Replication性能优化

时间:2016.04.19 发布人:Dnkmhlnv

MySQL 5.7增强版Semisync Replication性能优化

已解决问题

谷歌Dnkmhlnv用户在2016.04.19提交了关于“中山陵MySQL 5.7增强版Semisync Replication性能优化”的提问,欢迎大家涌跃发表自己的观点。目前共有1个回答,最后更新于2025-03-02T03:34:01。希望大家能够帮助她。

详细问题描述及疑问:期待您的答案,我不知道说什么才好,除了谢谢 !

希望以下的回答,能够帮助你。

第1个回答

用户名:dyingczy  

一前言

育己前文介绍了5.5/5.土又6版本的MySQLsem线句计占配容isync基础原理和配置,随着MySQL5.7的发布,新版本的MySQL修复了sem让脚办剂云树事足山样isync的一些bug并且增强了功能。

支持发送binlog和接受ack的异步化;
支持在事务commit前等待ACK;
在server层判断备库是否要求半同步以减少Plugin锁冲突;
某职零关构频终行精四率除binlog**mp线程和lock_log的冲突等等。

本文重点分析第1,2个改进项,因为原来的模式的确会影响系功卫统的tps,新的异步模式可以提高半同步模式下的系统事务处理能力。

二优化

1、支持发送bi设句输著费频nlog和接受ack的异步化

通过前面的介绍,我们知道SemisynchronousReplication模式下,app在主库上提交一个事务/event,MyS散矿原什齐QL将每个事务写入上血binary并且同步到到sl**e,master会等待至少一个sl**e通知:sl**e已经接收到传过来的events并写入relaylog,才返回给回话层写入成功,或者直到传送日志发生超时,系统自动将为异步复制模式。

整体流程的逻辑图

5.5版本semisync设计的缺点:

清缺新外调原理以及上图来看,旧版本的semisync受限于**mpthread,原因是**mpthread承担了两份不同且又十分频繁的任务:传送政采多历binlog给sl**e,还含圆赵印拉教其精需要等待sl**e反馈信息,而且这两个任务是串临南得行的,**mpthread必须等待sl**e返回之后才会传送下一个events事务。**mpthread已然成为整个半同步提高性能的瓶颈在高并发业务场景下,这样的机制会影响**库整体的TPS.

为了解决上述问题,在5将.7.4版本的semisync框架中,独立出一个纸ackcollectorthread,专门用于接收sl**e的反馈信息。这样master上有两个进程独立工作,可以同时维情树生文发送binlog到sla弱试元基个若蛋四践稳情ve,和接收sl兵称免越宜赶复统汉**e的反馈。整体流程的逻辑图

大体的实现思路是:

备库IO线程使用TCP协议和主库交互,读写socket可以同时进行,在开启主库semisync时,启动一个后台线程,使用select**备库连接socket;
**mp线程不再等待备库ACK;在ackreciver线程等待ACK时,**mp线程还能继续发送下一组groupcommit的binlog,进而提升TPS.

2支持在事务commit前等待ACK;

新版本的semisync增加了rpl_semi_sync_master_wait_point参数来控制半同步模式下主库在返回给会话事务成功之前提交事务的方式。

该参数有两个值:

AFTER_SYNC(默认值):master将每个事务写入binlog,传递到sl**e,并且刷新到磁盘。master等待sl**e反馈接收到事务并刷新到磁盘。一旦接到sl**e反馈,master在主库提交事务并且返回结果给会话。在AFTER_SYNC模式下,所有的客户端在同一时刻查看已经提交的**。假如发生主库crash,所有在主库上已经提交的事务已经同步到sl**e并记录到relaylog。此时切换到从库,可以保障最小的**损失。

AFTER_COMMIT:master将每个事务写入binlog,传递到sl**e刷新到磁盘(relaylog),然后在主库提交事务。master在提交事务后等待sl**e反馈接收到事务并刷新到磁盘。一旦接到sl**e反馈,master将结果反馈给客户端。
在AFTER_COMMIT模式下,如果sl**e没有应用日志,此时mastercrash,系统failover到sl**e,app将发现**出现不一致,在master提交而sl**e没有应用。