mysql半复制_MySQL半同步复制

1、半同步复制简介

何为半同步复制模式呢?在此我们先了解异步复制模式,这是MySQL的默认复制选项。异步复制即是master数据库把binlog日志发送给slave数据库,然后就没有了然后了。在此暴露一个问题,当slave服务器发生故障了,那么肯定会导致主从数据库服务器的数据不一致。

为了解决上面的问题,MySQL5.5引入一种叫做半同步复制模式。开启这种模式,可以保证slave数据库接收完master数据库发送过来的binlog日志并写入自己的中继日志中,然后反馈给master数据库,告知已经复制完毕。

开启这种模式后,当出现超时,主数据库将会自动转为异步复制模式,直到至少有一台从服务器接受到主数据库的binlog,并且反馈给主数据库。这时主数据库才会切换回半同步复制模式。

注意:

半同步复制模式必须在主服务器和从服务器同时中开启,否则将会默认为异步复制模式。

2、环境说明

两台linux虚拟主机

Linux版本CentOS6.6、MySQL 5.5

ip:192.168.95.11(主)、192.168.95.12(从)

3、安装与配置

3.1、安装前提

1、必须是MySQL5.5或者以上

2、MySQL必须有自动加载功能,即have_dynamic_loading变量为YES(因为我们是在MySQL里面来加载安装这个功能插件)

show variables like 'have_dynamic_loading';  #检查是否具有自动加载功能

886b396486763645894b4e9b97f618ed.png

3、主从复制已经配置好,并且已经ing工作着的。

3.2、安装

192.168.95.11加载安装:

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; #开启半同步复制,默认是关闭的

c817019377decff8c36e2611c2d9a7ba.png

192.168.95.12加载安装

48304ba5e6f9fe08f3fa1abda7d326ab.png

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;

48304ba5e6f9fe08f3fa1abda7d326ab.png

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:

f75e0e8bbabc408b2efea951151e7a70.png

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:

8fba272ad8ffe82555f7b424f2a0b1f7.png

Rpl_semi_sync_slave_enabled=ON表示在slave已经开始半同步复制模式

Rpl_semi_sync_slave_trace_level=32表示用于开启半同步复制时的调试级别,默认32

2、主从执行命令show status like '%semi%';

master

ce5d440b767139cd951d0380de6d9f52.png

Rpl_semi_sync_master_status表示主服务器使用是异步还是半同步复制

Rpl_semi_sync_master_client表示从服务器有多少个配置成半同步复制

Rpl_semi_sync_master_yes_tx表示从服务器确认成功提交的数量

Rpl_semi_sync_master_no_tx表示从服务器确认失败提交的数量

slave:

6de1029572774dde9071191fcb149a98.png

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:

d96f0b62b02c311e8a4c902cf6816582.png

slave:

b48aa4a028d55859cab5b59ae109d7e3.png

3、master在数据库中再创建tab2,不需要等待反馈,直接执行

【当反馈超时时,master将切换到异步复制模式。此时是异步模式,不需要等待】

169388534177cc4bd45bb711732ea3cf.png

4、slave执行start slave,数据开始同步,建立tab1、tab2,反馈给master,并切换为半同步复制

d9b430316594d469566c5ed3ea2351dc.png

5、slave执行stop slave;关闭主从复制

6、master在数据库中创建表tab3,此时需要等待10s,接收slave反馈信号;等待超时,切换为异步复制模式,继续执行

【步骤4时,数据同步已经反馈给master,此时master已经是半同步复制模式】

ddd9f541d27ba2ffcb571adfa4ecf64c.png

6、总结

半同步复制模式的性能和并发比异步复制模式低的,因为每次复制都要进行反馈,相比之下多了一个步骤。

说实话我还是不太明白为什么半同步复制就可以保持数据的完整性呢?若是slave挂了,master还不是变回异步复制。和之前的全异步没什么区别。还有就是即使多了个信息反馈,但是反馈回来除了让master确认还有什么作用?假若slave挂了,没有反馈信息,那master还是没什么进一步的处理方法呀。

毕竟我还是个小白,对mysql了解还不够深吧,若有大神知道的,请求指点指点。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值