阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

简述MySQL半同步复制—semisync

429次阅读
没有评论

共计 3090 个字符,预计需要花费 8 分钟才能阅读完成。

MySQL 的半同步复制 -semisync 是基于默认的异步复制和完全同步复制之间,它是在 master 在执行完客户端提交的事务后不是立刻返回给客户端,而是等待至少一个 slave 收到并写到 relay log 中才返回给客户端。相对于异步复制,semisync 提高了数据的安全性,但是又比完全同步性能好,所以 master 和 slave 之间的时间一定要一致,以免造成 semisync 失败。MySQL 的半同步复制的插件是由 Google 免费提供的在 MySQL 的 $basedir/lib/plugin 下有相应的动态库文件,linux 中是.so,DOS 系统中是.dll,在默认情况下 MySQL 是没有装载 semisync 的插件,所以要制作 semisync 要手动在 MySQL 的 shell 中装载插件,下面就简单的说一说 MySQL 的 semisync 配置, 这里要注意要使用 MySQL 的 super 用户来配置,并且 MySQL 要 5.5 及以上版本才有,并且要在有异步复制的基础上才可以做配置

#master 中
 
mysql> install plugin rpl_semi_sync_master soname ‘semisync_master.so’;
Query OK, 0 rows affected (0.00 sec)
mysql> show global variables like ‘%semi%’;                           
+————————————+——-+
| Variable_name                      | Value |
+————————————+——-+
| rpl_semi_sync_master_enabled      | OFF  | 
| rpl_semi_sync_master_timeout      | 10000 | 
| rpl_semi_sync_master_trace_level  | 32    | 
| rpl_semi_sync_master_wait_no_slave | ON    | 
+————————————+——-+
4 rows in set (0.01 sec)
mysql> set global rpl_semi_sync_master_enabled = 1;# 开启 master 上的 semisync,设置超时时间,可以通过设置 rpl_semi_sync_master_timeout 变量来修改,默认单位为毫秒
Query OK, 0 rows affected (0.00 sec)
mysql> show status like ‘%Rpl_semi_sync%’;
+——————————————–+——-+
| Variable_name                              | Value |
+——————————————–+——-+
| Rpl_semi_sync_master_clients              | 1    | 
| Rpl_semi_sync_master_net_avg_wait_time    | 565  | 
| Rpl_semi_sync_master_net_wait_time        | 3391  | 
| Rpl_semi_sync_master_net_waits            | 6    | 
| Rpl_semi_sync_master_no_times              | 1    | 
| Rpl_semi_sync_master_no_tx                | 12    | 
| Rpl_semi_sync_master_status                | ON    | 
| Rpl_semi_sync_master_timefunc_failures    | 0    | 
| Rpl_semi_sync_master_tx_avg_wait_time      | 588  | 
| Rpl_semi_sync_master_tx_wait_time          | 3528  | 
| Rpl_semi_sync_master_tx_waits              | 6    | 
| Rpl_semi_sync_master_wait_pos_backtraverse | 0    | 
| Rpl_semi_sync_master_wait_sessions        | 0    | 
| Rpl_semi_sync_master_yes_tx                | 6    | 
+——————————————–+——-+
14 rows in set (0.00 sec)
 
#slave 中
 
mysql> install plugin rpl_semi_sync_slave soname ‘semisync_slave.so’;       
Query OK, 0 rows affected (0.00 sec)
 
mysql> show global variables like ‘%semi%’;
+———————————+——-+
| Variable_name                  | Value |
+———————————+——-+
| rpl_semi_sync_slave_enabled    | OFF  |
| rpl_semi_sync_slave_trace_level | 32    |
+———————————+——-+
2 rows in set (0.00 sec)
mysql> set global rpl_semi_sync_slave_enabled = 1;
Query OK, 0 rows affected (0.00 sec)
mysql> stop slave IO_THREAD;start slave IO_THREAD;# 重启 slave 上的 IO 线程
Query OK, 0 rows affected (0.09 sec)
 
Query OK, 0 rows affected (0.00 sec)
mysql> show status like ‘%Rpl_semi_sync%’;
+—————————-+——-+
| Variable_name              | Value |
+—————————-+——-+
| Rpl_semi_sync_slave_status | ON    |
+—————————-+——-+
1 row in set (0.00 sec)

这样简单的 semisync 就配置好了,这里要注意的是如果 master 超过超时时间没有接收到 slave 的消息时会自动转为异步复制,当然如果不需要 semisync 可以直接 uninstall 相应的插件
mysql> uninstall plugin rpl_semi_sync_master;
Query OK, 0 rows affected (0.00 sec)
mysql> uninstall plugin rpl_semi_sync_slave;
Query OK, 0 rows affected (0.00 sec)

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-08/146257.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3090字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7803039
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
240 元左右!五盘位 NAS主机,7 代U硬解4K稳如狗,拓展性碾压同价位

240 元左右!五盘位 NAS主机,7 代U硬解4K稳如狗,拓展性碾压同价位

  240 元左右!五盘位 NAS 主机,7 代 U 硬解 4K 稳如狗,拓展性碾压同价位 在 NA...
星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定!

星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定!

星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定! 前言 作为 NAS 玩家,你是否总被这些...
星哥带你玩飞牛NAS-1:安装飞牛NAS

星哥带你玩飞牛NAS-1:安装飞牛NAS

星哥带你玩飞牛 NAS-1:安装飞牛 NAS 前言 在家庭和小型工作室场景中,NAS(Network Atta...
CSDN,你是老太太喝粥——无齿下流!

CSDN,你是老太太喝粥——无齿下流!

CSDN,你是老太太喝粥——无齿下流! 大家好,我是星哥,今天才思枯竭,不写技术文章了!来吐槽一下 CSDN。...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
240 元左右!五盘位 NAS主机,7 代U硬解4K稳如狗,拓展性碾压同价位

240 元左右!五盘位 NAS主机,7 代U硬解4K稳如狗,拓展性碾压同价位

  240 元左右!五盘位 NAS 主机,7 代 U 硬解 4K 稳如狗,拓展性碾压同价位 在 NA...
开发者福利:免费 .frii.site 子域名,一分钟申请即用

开发者福利:免费 .frii.site 子域名,一分钟申请即用

  开发者福利:免费 .frii.site 子域名,一分钟申请即用 前言 在学习 Web 开发、部署...
安装并使用谷歌AI编程工具Antigravity(亲测有效)

安装并使用谷歌AI编程工具Antigravity(亲测有效)

  安装并使用谷歌 AI 编程工具 Antigravity(亲测有效) 引言 Antigravity...
把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地 大家好,我是星哥,今天教大家在飞牛 NA...
零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face 免费服务器 +Docker 快速部署 HertzBeat 监控平台 ...