MySQL半同步复制
admin
2023-03-24 17:01:23
0

    

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';  #检查是否具有自动加载功能

MySQL半同步复制

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

      主从复制配置教程:h tt p:// w w w.cn blo gs.co m/ph pstud y2015-6/p/6485819.html


  3.2、安装

    192.168.95.11加载安装:

MySQL半同步复制

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

MySQL半同步复制

MySQL半同步复制

    192.168.95.12加载安装

MySQL半同步复制

 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;

MySQL半同步复制

 


  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:

MySQL半同步复制

  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:

MySQL半同步复制

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

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

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

  master

MySQL半同步复制

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

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

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

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

  slave:

MySQL半同步复制

  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:

    MySQL半同步复制

    slave:

    MySQL半同步复制

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

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

    MySQL半同步复制

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

   MySQL半同步复制

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

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

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

   MySQL半同步复制


6、总结

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

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


相关内容

热门资讯

玩家最新攻略“樱花之盛牛牛怎么... 您好:樱花之盛牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款...
今日重大通报“微信链接牛牛辅助... 今日重大通报“微信链接牛牛辅助器?”(原来真的有挂)您好,微信链接牛牛这个游戏其实有挂的,确实是有挂...
终于了解“飞鹰牛牛怎么装挂?”... 您好:飞鹰牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
昇思MindSpore开源五年... 12月25日,昇思人工智能框架峰会在杭州召开,本次大会的主题是“昇思MindSpore为超节点而生的...
谷歌将推出新功能:允许用户更改... 12月25日消息,谷歌公司表示目前正推出一款全新功能,将允许用户直接修改电子邮箱地址前缀(包括以“@...
正式迈入“三跑道”时代!西安咸... 12月25日早上8:00,南方航空CZ8822航班从西安咸阳国际机场新建南二跑道起飞,标志着机场正式...
【第一资讯】“飞鹰炸/金/花到... 您好:飞鹰炸/金/花这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这...
今日重大发现“白金岛三打哈开挂... 网上科普关于“白金岛三打哈有没有挂”话题很是火热,小编也是针对白金岛三打哈作*弊开挂的方法以及开挂对...
玩家攻略科普“十三十三水经典比... 有 亲,根据资深记者爆料十三十三水经典比鸡是可以开挂的,确实有挂(咨询软...
【第一资讯】“白金岛十胡卡有挂... 有 亲,根据资深记者爆料白金岛十胡卡是可以开挂的,确实有挂(咨询软件无需...