首页 / MYSQL / MySQL半同步复制
MySQL半同步复制
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL半同步复制,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4536字,纯文字阅读大概需要7分钟。
内容图文
![MySQL半同步复制](/upload/InfoBanner/zyjiaocheng/482/b653cbe1988f400cab0660bc0e35208c.jpg)
1 mysql>install plugin rpl_semi_sync_master soname ‘semisync_master.so‘;2 3 mysql>show plugins; #查看是否加载成功4 5 mysql>SET GLOBAL rpl_semi_sync_master_enabled = 1; #开启半同步复制,默认是关闭的
192.168.95.12加载安装
1 mysql>INSTALL PLUGIN rpl_semi_sync_slave SONAME ‘semisync_slave.so‘; 2 3 mysql>show plugins; #查看是否加载成功 4 5 mysql>SET GLOBAL rpl_semi_sync_slave_enabled = 1; #开启半同步复制,默认是关闭的 6 7 #重启从服务器IO线程,手动将异步模式切换为半同步模式 8 9 mysql>STOP SLAVE IO_THREAD;10 11 mysql>START SLAVE IO_THREAD;
3.3、配置文件
1 rpl_semi_sync_master_enabled=1 #主库配置文件添加,表示以后启动MySQL将会自动开启半同步复制2 3 rpl_semi_sync_slave_enabled=1 #从库配置文件添加,同上
4、查看相关参数
1、主从执行命令show variables like ‘%semi%‘;
master:
Rpl_semi_sync_master_enabled=ON表示开启半同步复制
Rpl_semi_sync_master_timeout=1000默认1000毫秒,即10秒超时,将切换为异步复制
Rpl_semi_sync_master_wait_no_slave表示是否允许master每个事物都要等待slave接收确认,默认为ON
Rpl_semi_sync_master_trace_level=32表示用于开启半同步复制时的调试级别,默认32
slave:
Rpl_semi_sync_slave_enabled=ON表示在slave已经开始半同步复制模式
Rpl_semi_sync_slave_trace_level=32表示用于开启半同步复制时的调试级别,默认32
2、主从执行命令show status like ‘%semi%‘;
master
Rpl_semi_sync_master_status表示主服务器使用是异步还是半同步复制
Rpl_semi_sync_master_client表示从服务器有多少个配置成半同步复制
Rpl_semi_sync_master_yes_tx表示从服务器确认成功提交的数量
Rpl_semi_sync_master_no_tx表示从服务器确认失败提交的数量
slave:
Rpl_semi_sync_slave_status表示从服务器开启半同步复制
5、测试
模拟slave挂掉,master等待10s仍没接收到反馈信号,则转为异步复制模式,继续执行
首先同步创建数据库aa
1、slave执行stop slave;关闭主从复制
2、master在aa数据库中创建表tab1,没接收到反馈信号,等待十秒后(Rpl_semi_sync_master_timeout=1000等待超时),继续执行
master:
slave:
3、master在数据库中再创建tab2,不需要等待反馈,直接执行
【当反馈超时时,master将切换到异步复制模式。此时是异步模式,不需要等待】
4、slave执行start slave,数据开始同步,建立tab1、tab2,反馈给master,并切换为半同步复制
5、slave执行stop slave;关闭主从复制
6、master在数据库中创建表tab3,此时需要等待10s,接收slave反馈信号;等待超时,切换为异步复制模式,继续执行
【步骤4时,数据同步已经反馈给master,此时master已经是半同步复制模式】
6、总结
半同步复制模式的性能和并发比异步复制模式低的,因为每次复制都要进行反馈,相比之下多了一个步骤。
说实话我还是不太明白为什么半同步复制就可以保持数据的完整性呢?若是slave挂了,master还不是变回异步复制。和之前的全异步没什么区别。还有就是即使多了个信息反馈,但是反馈回来除了让master确认还有什么作用?假若slave挂了,没有反馈信息,那master还是没什么进一步的处理方法呀。
MySQL半同步复制
标签:虚拟主机 服务器 master linux 数据库
本文系统来源:http://12879490.blog.51cto.com/12869490/1923143
内容总结
以上是互联网集市为您收集整理的MySQL半同步复制全部内容,希望文章能够帮你解决MySQL半同步复制所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。