MySQL的半同步模式

MySQL 的半同步复制

MySQL 的半同步复制(Semi-Synchronous Replication, SSR)是一种增强的复制机制,旨在减少主服务器(Master)发生故障时的数据丢失风险,并在一定程度上提高复制的可靠性。半同步复制结合了异步复制和全同步复制的优点,既提高了系统的可用性也增强了数据的一致性。

半同步复制的工作原理

在传统的异步复制中,主服务器将事务提交到二进制日志(bin-log)后,会立即向客户端返回成功响应,而不管从服务器(Slave)是否已经接收到该事务。这种方式虽然提供了较高的系统吞吐量,但在主服务器突然宕机的情况下,尚未被从服务器接收的事务可能会丢失。

在全同步复制中,主服务器只有在至少一个从服务器确认接收到事务后才会返回成功响应。这种方法虽然保证了数据的一致性,但由于等待从服务器确认的时间可能会造成性能下降。

半同步复制则试图在这两者之间找到平衡。在这种模式下,主服务器在提交事务前会等待至少一个从服务器确认接收到了该事务的二进制日志事件。一旦得到确认,主服务器就会向客户端返回成功响应,并继续处理下一个事务。这样做的好处是,在大多数情况下,可以保证至少有一个从服务器拥有最新的数据,从而减少了数据丢失的风险。

1.用户线程写入完成后master中的dump会把日志推送到slave端

2.slave中的io线程接收后保存到relaylog中继日志

3.保存完成后slave向master端返回ack

4.在未接受到slave的ack时master端时不做提交的,一直处于等待当收到ack后提交到存储引擎

5.在5.6版本中用到的时after_commit模式,after_commit模式时先提交在等待ack返回后输出ok

配置半同步复制

要配置 MySQL 的半同步复制,您需要对主服务器和从服务器进行一些特定的配置。以下是基本的配置步骤:

主服务器配置
  1. 安装半同步插件:确保您的 MySQL 版本支持半同步插件。对于 MySQL 5.7 及更高版本,半同步复制插件通常是默认包含的。如果您的 MySQL 版本不包含此插件,您需要手动安装。

  2. 配置主服务器 :编辑 MySQL 的配置文件(通常是 my.cnfmy.ini),添加半同步复制相关的配置项。

bash 复制代码
[mysqld]
datadir=/data/mysql
socket=/data/mysql/mysql.sock
server-id=1
log-bin=mysql-bin
gtid_mode=ON
enforce-gtid-consistency=ON
rpl_semi_sync_master_enabled=1 
symbolic-links=0

rpl_semi_sync_master_enabled=1启用半同步功能

3.安装半同步插件

sql 复制代码
INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';

4.查看插件情况

sql 复制代码
mysql> SELECT PLUGIN_NAME, PLUGIN_STATUS
-> FROM INFORMATION_SCHEMA.PLUGINS
-> WHERE PLUGIN_NAME LIKE '%semi%';
+----------------------+---------------+
| PLUGIN_NAME | PLUGIN_STATUS |
+----------------------+---------------+
| rpl_semi_sync_master | ACTIVE |
+----------------------+---------------+
1 row in set (0.01 sec)

5.打开半同步功能

sql 复制代码
SET GLOBAL rpl_semi_sync_master_enabled = 1;
从服务器配置
  1. 安装半同步插件:安装半同步复制插件。
sql 复制代码
INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
  1. 配置从服务器:同样编辑 MySQL 的配置文件,添加半同步复制相关的配置项。
bash 复制代码
[mysqld]
datadir=/data/mysql
socket=/data/mysql/mysql.sock
server-id=1
log-bin=mysql-bin
gtid_mode=ON
enforce-gtid-consistency=ON
rpl_semi_sync_master_enabled=1 #开启半同步功能
symbolic-links=0
  • rpl_semi_sync_slave_enabled: 启用半同步复制。
  1. 重启 MySQL 服务:重启 IO线程,半同步服务才能生效。
sql 复制代码
 STOP SLAVE IO_THREAD; 
 START SLAVE IO_THREAD; 
设置复制关系

完成上述配置后,您需要按照常规的主从复制配置步骤来建立主从复制关系。包括创建复制用户、获取主服务器的二进制日志文件名和位置、初始化从服务器数据、配置从服务器指向主服务器等。

测试半同步复制

  • 检查状态 :您可以使用 SHOW VARIABLES LIKE '%semi_sync%'; 来检查半同步复制的相关变量是否已被正确设置。
  • 监控状态 :通过 SHOW STATUS LIKE '%semi_sync%'; 查看半同步复制的运行状态。

注意事项

  • 性能影响:半同步复制会增加主服务器的延迟,因为主服务器需要等待从服务器的确认才能继续处理下一个事务。不过,由于只需要等待至少一个从服务器的确认,所以性能影响相对较小。
  • 配置灵活性 :您可以选择等待一个以上的从服务器确认。这可以通过修改 rpl_semi_sync_master_wait_for_slave_count 变量来实现。
  • 故障转移 :半同步复制本身并不提供自动故障转移的功能。您需要另外配置故障检测和自动切换机制,如使用 MySQL Group ReplicationPercona XtraDB Cluster 等解决方案。
相关推荐
alexhilton18 小时前
面向开发者的系统设计:像建筑师一样思考
android·kotlin·android jetpack
逛逛GitHub1 天前
斩获 2 万多 Star!国外老哥把全网 n8n 工作流都开源了
github·工作流引擎
Java水解1 天前
Mysql查看执行计划、explain关键字详解(超详细)
后端·mysql
CYRUS_STUDIO1 天前
用 Frida 控制 Android 线程:kill 命令、挂起与恢复全解析
android·linux·逆向
CYRUS_STUDIO1 天前
Frida 实战:Android JNI 数组 (jobjectArray) 操作全流程解析
android·逆向
知其然亦知其所以然1 天前
MySQL 社招必考题:如何优化查询过程中的数据访问?
后端·mysql·面试
杨杨杨大侠1 天前
Atlas Mapper 案例 01:初级开发者 - 电商订单系统开发
java·开源·github
用户091 天前
Gradle Cache Entries 深度探索
android·java·kotlin
循环不息优化不止1 天前
安卓 View 绘制机制深度解析
android
叽哥1 天前
Kotlin学习第 9 课:Kotlin 实战应用:从案例到项目
android·java·kotlin