mysql确认半同步命令_MySQL复制全解析 Part 3 MySQL半同步复制设置

实验环境

此次实验的环境如下MySQL 5.7.25

Redhat 6.10

操作系统账号:mysql

数据库复制账号:repl

复制格式:基于行的复制

上节我们介绍了如何一步步搭建MySQL复制

这节说如何启用半同步功能

1. 半同步介绍

我们在Part 2中搭建的复制实际上是异步的复制,主库将二进制日志发送到从库后并不需要确认从库是否接受并应用,这时就可能会造成数据丢失

MySQL 从5.5版本后推出了半同步的功能,相当于Oracle DG的最大保护模式,它要求从库在接收并应用日志后,主库才提交完成,保证了数据。

开启半同步需要如下要求MySQL 5.5及以上版本

变量have_dynamic_loading为YES

异步复制已经存在

2. 加载半同步插件

因需执行INSTALL PLUGIN, SET GLOBAL, STOP SLAVE和START SLAVE操作,所以用户需有SUPER权限

主库和从库

mysql> INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';

mysql> INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';

这里安装半同步的master和slave插件

考虑到后面主从可能需要切换,这里在主从库上都安装

3. 确认是否加载成功

mysql> show plugins;

mysql> SELECT PLUGIN_NAME, PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE PLUGIN_NAME LIKE '%semi%';

4. 启用半同步

首先我们启用半同步插件

主库

mysql> SET GLOBAL rpl_semi_sync_master_enabled = 1;

从库

mysql> SET GLOBAL rpl_semi_sync_slave_enabled = 1;

之后需要重启IO线程才能使半同步生效,也可直接重启复制

从库

mysql> STOP SLAVE IO_THREAD;

mysql> START SLAVE IO_THREAD;

如果从库超过一定时间不能和主库进行通信,则会自动降为异步模式

该时间由rpl_semi_sync_master_timeout参数控制,单位为毫秒

5. 查看半同步状态

我们使用如下命令查看半同步是否正常工作

主库的master和从库的slave都需要为ON

主库

mysql> show status like 'Rpl_semi_sync_master_status';

mysql> show status like 'Rpl_semi_sync_slave_status';

从库

mysql> show status like 'Rpl_semi_sync_slave_status';

mysql> show status like 'Rpl_semi_sync_master_status';

6. 写入配置文件

接下来我们将命令写在配置文件中以使重启后自动启动

考虑到后面主从可能需要切换,这里在主从库上半同步的master和slave都设置为启动

主库和从库

plugin_dir = /usr/local/mysql/lib/plugin

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

rpl_semi_sync_master_timeout = 5000

7. 参考资料

本专题内容翻译自官方文档并结合自己的环境MySQL 5.7 Reference Manual :: 16 Replication​dev.mysql.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值