MySQL 5.7增强版Semisync Replication性能优化

作者:junjie 时间:2024-01-22 21:39:04 

一 前言

前文 介绍了5.5/5.6 版本的MySQL semi sync 基础原理和配置,随着MySQL 5.7 的发布,新版本的MySQL修复了semi sync 的一些bug 并且增强了功能。

支持发送binlog和接受ack的异步化;
支持在事务commit前等待ACK;
在server层判断备库是否要求半同步以减少Plugin锁冲突;
解除binlog dump线程和lock_log的冲突等等。

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

二 优化

1、支持发送binlog和接受ack的异步化

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

整体流程的逻辑图

MySQL 5.7增强版Semisync Replication性能优化

5.5 版本semi sync 设计的缺点:

    从原理以及上图来看,旧版本的semi sync 受限于dump thread ,原因是dump thread 承担了两份不同且又十分频繁的任务:传送binlog 给slave ,还需要等待slave反馈信息,而且这两个任务是串行的,dump thread 必须等待 slave 返回之后才会传送下一个 events 事务。dump thread 已然成为整个半同步提高性能的瓶颈在高并发业务场景下,这样的机制会影响数据库整体的TPS .

为了解决上述问题,在5.7.4版本的semi sync 框架中,独立出一个 ack collector thread ,专门用于接收slave 的反馈信息。这样master 上有两个进程独立工作,可以同时发送binlog 到slave ,和接收slave的反馈。整体流程的逻辑图

MySQL 5.7增强版Semisync Replication性能优化

大体的实现思路是:

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

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

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

该参数有两个值:

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

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

标签:MySQL,5.7,增强,Semisync,Replication,性能优化
0
投稿

猜你喜欢

  • django 修改server端口号的方法

    2022-05-08 15:49:10
  • python正则表达式中的括号匹配问题

    2023-07-26 01:36:24
  • numpy模块中axis的理解与使用

    2023-06-26 22:55:28
  • sqlserver 日期比较、日期查询常用语句:月的第一天,季度的第一天等

    2010-08-01 18:58:00
  • 利用Python获取赶集网招聘信息前篇

    2021-09-23 12:53:36
  • Django数据库迁移报错InconsistentMigrationHistory

    2024-01-18 16:32:26
  • AI与Python人工智能启发式搜索概念理解

    2021-08-05 03:56:28
  • SQL SERVER的优化建议与方法

    2024-01-20 15:14:58
  • python代码实现烟花实例

    2022-09-13 18:09:18
  • python selenium自动化测试框架搭建的方法步骤

    2023-05-24 21:38:49
  • Python读写锁实现实现代码解析

    2023-06-16 23:27:12
  • JavaScript用Number方法实现string转int

    2024-05-11 09:33:43
  • Asp中Server.ScriptTimeOut属性需要注意的一点

    2011-04-27 08:41:00
  • php引用返回与取消引用的详解

    2023-11-20 02:50:07
  • python实现的文件夹清理程序分享

    2021-07-20 07:58:57
  • Python定时爬取微博热搜示例介绍

    2022-09-18 21:59:18
  • 在ASP中使用SQL语句之5:开始执行

    2007-08-11 12:36:00
  • Python中pygal绘制雷达图代码分享

    2023-09-27 10:03:59
  • Python3实现将文件树中所有文件和子目录归档到tar压缩文件的方法

    2022-11-29 08:22:38
  • SQL窗口函数之聚合窗口函数的使用(count,max,min,sum)

    2024-01-21 00:56:09
  • asp之家 网络编程 m.aspxhome.com