MySQL复制全解析 Part 3 MySQL半同步复制设置
前情提要
MySQL复制全解析 Part 2 一步步搭建基于二进制文件位置的MySQL复制
实验环境
此次实验的环境如下
- MySQL 5.7.25
- Redhat 6.10
- 操作系统账号:mysql
- 数据库复制账号:repl
- 复制格式:基于行的复制
IP地址 |
主从关系 |
复制账号 |
复制格式 |
---|---|---|---|
11.12.14.29 |
主库 |
repl |
Row-Based |
11.12.14.30 |
从库(半同步) |
repl |
Row-Based |
上节我们介绍了如何一步步搭建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. 参考资料
本专题内容翻译自官方文档并结合自己的环境
https://dev.mysql.com/doc/refman/5.7/en/replication.html
觉得文章不错的欢迎关注,转发,收藏~
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解