0

0

MySQL 5.5半同步复制

php中文网

php中文网

发布时间:2016-06-07 16:48:42

|

1260人浏览过

|

来源于php中文网

原创

mysql在主从复制还支持半同步复制,mysql复制是异步的,因为同步性能非常差。主库分发事件以后必须等待从库复制数据结束并收到从

一、实验目的:

mysql在主从复制还支持半同步复制,mysql复制是异步的,因为同步性能非常差。主库分发事件以后必须等待从库复制数据结束并收到从库正常响应以后,才能进行下一步操作。异步模式导致从库落后主库时,,主库无从得知。因此mysql5.5后引入google补丁半同步复制,2个插件:semisync_master.so与semisync_slave.so。半同步:一主多从架构中,主库只等待一台从库复制完成数据并返回正常响应,就认为同步完成进行下一步操作,这样即有异步的高速,又有同步的安全。一旦主库等待从库响应超时,半同步复制自动降级为异步复制。半同步复制前提至少有一台从库与主库在同一机房,保证足够带宽,数据复制也足够快。因为对写性能影响极大又需要同步确认等待。

说说MySQL的半同步复制

MySQL基于SSL的半同步复制

MySQL主从,半同步,主主复制

MySQL服务器复制的主从架构半同步的实现

MySQL半同步复制(Semi-synchronous Replication)

MySQL5.5配置安装半同步复制

二、实验步骤

1.mysql支持的模块/插件

[root@master~]# ls -t /usr/local/mysql/lib/plugin/

debug  semisync_slave.so  mypluglib.so  qa_auth_interface.so  qa_auth_client.so  adt_null.so daemon_example.ini  semisync_master.so  libdaemon_example.so  qa_auth_server.so  auth_test_plugin.so  auth_socket.so  auth.so

2.半同步模块安装

2.1主库

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

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  | 没有从库也要等一下

+------------------------------------+-------+

mysql>SET GLOBAL rpl_semi_sync_master_enabled=1;

mysql>SET GLOBAL rpl_semi_sync_master_timeout=1000;

mysql>SHOW GLOBAL STATUS LIKE '%semi%';

+--------------------------------------------+-------+

|Variable_name                              | Value |

+--------------------------------------------+-------+

|Rpl_semi_sync_master_clients              | 1    | 从节点1个

|Rpl_semi_sync_master_net_avg_wait_time    | 0    |

|Rpl_semi_sync_master_net_wait_time        | 0    |

|Rpl_semi_sync_master_net_waits            | 0    |

|Rpl_semi_sync_master_no_times            | 0    |

|Rpl_semi_sync_master_no_tx                | 0    |

|Rpl_semi_sync_master_status              | ON    |

|Rpl_semi_sync_master_timefunc_failures    | 0    |

|Rpl_semi_sync_master_tx_avg_wait_time    | 0    |

|Rpl_semi_sync_master_tx_wait_time        | 0    |

|Rpl_semi_sync_master_tx_waits            | 0    |

|Rpl_semi_sync_master_wait_pos_backtraverse | 0    |

|Rpl_semi_sync_master_wait_sessions        | 0    |

|Rpl_semi_sync_master_yes_tx              | 0    |

+--------------------------------------------+-------+

mysql>USE school;

mysql>CREATE TABLE tb2(name CHAR(20));

mysql>SHOW GLOBAL STATUS LIKE '%semi%';

+--------------------------------------------+-------+

|Variable_name                            | Value |

+--------------------------------------------+-------+

|Rpl_semi_sync_master_clients              | 1    |

|Rpl_semi_sync_master_net_avg_wait_time    | 800  | 等待从服返回报告时间

|Rpl_semi_sync_master_net_wait_time        | 800  |

|Rpl_semi_sync_master_net_waits            | 1    |

|Rpl_semi_sync_master_no_times            | 0    |

|Rpl_semi_sync_master_no_tx                | 0    |

|Rpl_semi_sync_master_status              | ON    |

|Rpl_semi_sync_master_timefunc_failures    | 0    |

|Rpl_semi_sync_master_tx_avg_wait_time    | 715  | 等待从服事务返回报告时间

|Rpl_semi_sync_master_tx_wait_time        | 715  |

|Rpl_semi_sync_master_tx_waits            | 1    |

|Rpl_semi_sync_master_wait_pos_backtraverse | 0    |

|Rpl_semi_sync_master_wait_sessions        | 0    |

|Rpl_semi_sync_master_yes_tx              | 1    |

+--------------------------------------------+-------+

mysql>INSERT INTO tb2 VALUES ('tom'),('jerry'),('jack');

mysql>SHOW GLOBAL STATUS LIKE '%semi%';

+--------------------------------------------+-------+

|Variable_name                            | Value |

+--------------------------------------------+-------+

|Rpl_semi_sync_master_clients              | 1    |

|Rpl_semi_sync_master_net_avg_wait_time    | 1518  |

|Rpl_semi_sync_master_net_wait_time        | 3037  |

|Rpl_semi_sync_master_net_waits            | 2    |

|Rpl_semi_sync_master_no_times            | 0    |

|Rpl_semi_sync_master_no_tx                | 0    |

|Rpl_semi_sync_master_status              | ON    |

|Rpl_semi_sync_master_timefunc_failures    | 0    |

|Rpl_semi_sync_master_tx_avg_wait_time    | 715  |

|Rpl_semi_sync_master_tx_wait_time          | 715  |

|Rpl_semi_sync_master_tx_waits            | 1    |

|Rpl_semi_sync_master_wait_pos_backtraverse | 0    |

|Rpl_semi_sync_master_wait_sessions        | 0    |

|Rpl_semi_sync_master_yes_tx              | 2    |

+--------------------------------------------+-------+


 

从库

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

mysql>SHOW GLOBAL VARIABLES LIKE '%semi%';

+---------------------------------+-------+

|Variable_name                  | Value |

+---------------------------------+-------+

|rpl_semi_sync_slave_enabled    |OFF  |

|rpl_semi_sync_slave_trace_level | 32    |

+---------------------------------+-------+

mysql>SET GLOBAL rpl_semi_sync_slave_enabled=1;

mysql>STOP SLAVE;

mysql>START SLAVE;

mysql>SHOW GLOBAL STATUS LIKE '%semi%';

+----------------------------+-------+

|Variable_name              | Value |

+----------------------------+-------+

|Rpl_semi_sync_slave_status | ON    |

+----------------------------+-------+

永久配置在Master和Slave的my.cnf中编辑:

# OnMaster

[root@master~]# vim /etc/my.cnf

[mysqld]

rpl_semi_sync_master_enabled=1

rpl_semi_sync_master_timeout=1000# 1 second

验证

mysql>SHOW GLOBAL VARIABLES LIKE '%semi%';

+------------------------------------+-------+

|Variable_name                      | Value |

+------------------------------------+-------+

|rpl_semi_sync_master_enabled      |ON    |

|rpl_semi_sync_master_timeout      |1000  |

|rpl_semi_sync_master_trace_level  |32    |

|rpl_semi_sync_master_wait_no_slave | ON  |

+------------------------------------+-------+

 

# OnSlave

[root@slave~]# vim /etc/my.cnf

[mysqld]

rpl_semi_sync_slave_enabled=1

验证

mysql>SHOW GLOBAL VARIABLES LIKE '%semi%';

+---------------------------------+-------+

|Variable_name                  | Value |

+---------------------------------+-------+

|rpl_semi_sync_slave_enabled    | ON    |

|rpl_semi_sync_slave_trace_level | 32    |

+---------------------------------+-------+

本文永久更新链接地址:

linux

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

32

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

23

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

16

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.31

Golang人工智能合集
Golang人工智能合集

本专题整合了Golang人工智能相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.31

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

268

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

195

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

170

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

85

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
mysql8主从复制原理底层详解
mysql8主从复制原理底层详解

共1课时 | 546人学习

mysql8主从复制原理底层详解
mysql8主从复制原理底层详解

共1课时 | 546人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号