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 等解决方案。
相关推荐
i道i4 小时前
MySQL win安装 和 pymysql使用示例
数据库·mysql
Oak Zhang5 小时前
sharding-jdbc自定义分片算法,表对应关系存储在mysql中,缓存到redis或者本地
redis·mysql·缓存
长亭外的少年6 小时前
Kotlin 编译失败问题及解决方案:从守护进程到 Gradle 配置
android·开发语言·kotlin
久醉不在酒6 小时前
MySQL数据库运维及集群搭建
运维·数据库·mysql
WindFutrue6 小时前
使用Mybatis向Mysql中的插入Point类型的数据全方位解析
数据库·mysql·mybatis
一只爱撸猫的程序猿8 小时前
一个简单的Linux 服务器性能优化案例
linux·mysql·nginx
计算机毕设源码qq-38365310418 小时前
(附项目源码)Java开发语言,215 springboot 大学生爱心互助代购网站,计算机毕设程序开发+文案(LW+PPT)
java·开发语言·spring boot·mysql·课程设计
袁庭新8 小时前
Cannal实现MySQL主从同步环境搭建
java·数据库·mysql·计算机·java程序员·袁庭新
建群新人小猿8 小时前
会员等级经验问题
android·开发语言·前端·javascript·php
爱学习的白杨树8 小时前
MySQL中有哪几种锁?
数据库·mysql