Mysql 半同步复制

Mysql 半同步复制

1、半同步复制简介

1)默认情况下,MySQL的复制功能是异步的,异步复制可以提供最佳的性能, 主库把binlog日志发送给从库,这一动作就结束了,并不会验证从库是否接收完毕,这一过程,也就意味着有可能出现当主服务器或从服务器端发生故障的时 候,有可能从服务器没有接收到主服务器发送过来的binlog日志,这就会造成主服务器和从服务器的数据不一致,甚至在恢复时造成数据的丢失。

注意:

半同步复制模式必须在主服务器和从服务器端同时开启,否则主服务器默认使用异步复制模式。

2)异步复制案例:

MySQL5.7数据库主从(Master/Slave)同步安装与配置详解

3)为了解决上述可能发生的错误,MySQL 5.5 引入了一种半同步复制模式。该模式可以确保从服务器接收完主服务器发送的binlog日志文件并写入到自己的中继日志relay log里,然后会给主服务器一个反馈,告诉主服务器已经接收完毕,这时主服务线程才返回给当前session告知操作完成。

4)当出现超时情况是,主服务器会暂时切换到异步复制模式,直到至少有一个从服务器从及时收到信息为止。

5)中继日志的自我修复:

MySQL 5.5.X 版本开始,增加了relay_log_recovery参数,这个参数的作用是:当slave从库宕机后,假如relay.log损坏了,导致一部分中继日志没有处理,则自动放弃所有未执行的relay-log,并且重新从master上获取日志,这样就保证了relay-log的完整性。默认情况下该功能是关闭的,将relay_log_recovery的值设置为1时,可在slave从库上开启该功能,建议开启。

6)半同步复制与异步复制的切换:

半同步复制的工作原理就是当slave从库IO_Thread线程将binlog日志接收完毕之后,要给master主库一个确认,如果rpl_semi_sync_master_timeout=10000 (10)超过10秒未收到slave从库的接受确认信号,那么就会自动切换为传统的异步复制模式。

2.环境说明
master172.25.27.1 (mysql5.7)

Slave 172.25.27.2 (mysql5.7)

3、安装与配置

安装前提
1、必须是MySQL5.5或者以上
2、MySQL必须有自动加载功能,即have_dynamic_loading变量为YES(因为我们是在MySQL里面来加载安装这个功能插件)

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


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


安装

Master172.25.27.1加载安装:

1 mysql>install plugin rpl_semi_sync_master soname 'semisync_master.so';

2 mysql>show plugins;   #查看是否加载成功

3 mysql>SET GLOBALrpl_semi_sync_master_enabled = 1;  #开启半同步复制,默认是关闭的

Slave172.25.27.2 加载安装

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

2mysql>show plugins;   #查看是否加载成功

3 mysql>SET GLOBAL rpl_semi_sync_slave_enabled = 1;  #开启半同步复制,默认是关闭的

4 #重启从服务器IO线程,手动将异步模式切换为半同步模式

mysql>STOP SLAVE IO_THREAD;

mysql>START SLAVE IO_THREAD;


修改配置文件

vim /etc/my.cnf

rpl_semi_sync_master_enabled=1  #主库配置文件添加,表示以后启动MySQL将会自动开启半同步复制

rpl_semi_sync_slave_enabled=1  #从库配置文件添加,同上

/etc/init.d/mysqld restart 重新启动mysql

4、查看相关参数

 

1、主从执行命令show variables like '%semi%';

  master:

Rpl_semi_sync_master_enabled=ON表示开启半同步复制

 Rpl_semi_sync_master_timeout=10000默认10000毫秒,即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表示从服务器开启半同步复制

4、测试

模拟slave挂掉,master等待10s仍没接收到反馈信号,则转为异步复制模式,继续执行

  首先同步创建数据库aa

  1slave执行stop slave;关闭主从复制

  2masterhaha数据库中创建表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已经是半同步复制模式】


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

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值