前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL复制全解析 Part 3 MySQL半同步复制设置

MySQL复制全解析 Part 3 MySQL半同步复制设置

作者头像
bsbforever
发布2020-08-18 15:40:36
8870
发布2020-08-18 15:40:36
举报
文章被收录于专栏:时悦的学习笔记

前情提要

MySQL复制全解析 Part 1 实验环境介绍

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权限

主库和从库

代码语言:javascript
复制
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. 确认是否加载成功

代码语言:javascript
复制
mysql> show plugins;
代码语言:javascript
复制
mysql> SELECT PLUGIN_NAME, PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE PLUGIN_NAME LIKE '%semi%';

4. 启用半同步

首先我们启用半同步插件

主库

代码语言:javascript
复制
mysql> SET GLOBAL rpl_semi_sync_master_enabled = 1;

从库

代码语言:javascript
复制
mysql> SET GLOBAL rpl_semi_sync_slave_enabled = 1;

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

从库

代码语言:javascript
复制
mysql> STOP SLAVE IO_THREAD;

mysql> START SLAVE IO_THREAD;

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

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

5. 查看半同步状态

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

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

主库

代码语言:javascript
复制
mysql> show status like 'Rpl_semi_sync_master_status';
代码语言:javascript
复制
mysql> show status like 'Rpl_semi_sync_slave_status';

从库

代码语言:javascript
复制
mysql> show status like 'Rpl_semi_sync_slave_status';
代码语言:javascript
复制
mysql> show status like 'Rpl_semi_sync_master_status';

6. 写入配置文件

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

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

主库和从库

代码语言:javascript
复制
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

觉得文章不错的欢迎关注,转发,收藏~

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-06-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 宅必备 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 实验环境
  • 1. 半同步介绍
  • 2. 加载半同步插件
  • 3. 确认是否加载成功
  • 4. 启用半同步
  • 5. 查看半同步状态
  • 6. 写入配置文件
  • 7. 参考资料
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档