## 实验环境 此次实验的环境如下 - 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; ``` [image:636 size:orig] ``` mysql> SELECT PLUGIN_NAME, PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE PLUGIN_NAME LIKE '%semi%'; ``` [image:637 size:orig] ## 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'; ``` [image:638 size:orig] ``` mysql> show status like 'Rpl_semi_sync_slave_status'; ``` [image:639 size:orig] **从库** ``` mysql> show status like 'Rpl_semi_sync_slave_status'; ``` [image:640 size:orig] ``` mysql> show status like 'Rpl_semi_sync_master_status'; ``` [image:641 size:orig] ## 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](https://dev.mysql.com/doc/refman/5.7/en/replication.html)