MYSQL数据库MySQL半同步复制
《MYSQL数据库MySQL半同步复制》要点: 1、半同步复制简介MYSQL入门 何为半同步复制模式呢?在此我们先了解异步复制模式,当slave服务器发生故障了,那么肯定会导致主从数据库服务器的数据不一致. MYSQL入门 为了解决上面的问题,MySQL5.5引入一种叫做半同步复制模式.开启这种模式,可以保证slave数据库接收完master数据库发送过来的binlog日志并写入自己的中继日志中,然后反馈给master数据库,告知已经复制完毕. MYSQL入门 开启这种模式后,当出现超时,主数据库将会自动转为异步复制模式,直到至少有一台从服务器接受到主数据库的binlog,并且反馈给主数据库.这时主数据库才会切换回半同步复制模式. MYSQL入门注意: MYSQL入门半同步复制模式必须在主服务器和从服务器同时中开启,否则将会默认为异步复制模式. 2、环境说明MYSQL入门 两台linux虚拟主机 MYSQL入门 Linux版本CentOS6.6、MySQL 5.5 MYSQL入门 ip:192.168.95.11(主)、192.168.95.12(从) 3、安装与配置3.1、安装前提MYSQL入门 1、必须是MySQL5.5或者以上 MYSQL入门 2、MySQL必须有自动加载功能,即have_dynamic_loading变量为YES(因为我们是在MySQL里面来加载安装这个功能插件) MYSQL入门 ?show variables like 'have_dynamic_loading';? #检查是否具有自动加载功能 MYSQL入门 MYSQL入门 3、主从复制已经配置好,并且已经ing工作着的. MYSQL入门 ?主从复制配置教程:http://www.cnblogs.com/phpstudy2015-6/p/6485819.html 3.2、安装MYSQL入门? MYSQL入门 192.168.95.11加载安装:
MYSQL入门
MYSQL入门? 3.3、配置文件
4、查看相关参数MYSQL入门 1、主从执行命令show variables like '%semi%'; MYSQL入门 master: MYSQL入门 MYSQL入门 Rpl_semi_sync_master_enabled=ON表示开启半同步复制 MYSQL入门 Rpl_semi_sync_master_timeout=1000默认1000毫秒,即10秒超时,将切换为异步复制 MYSQL入门 Rpl_semi_sync_master_wait_no_slave表示是否允许master每个事物都要等待slave接收确认,默认为ON MYSQL入门 Rpl_semi_sync_master_trace_level=32表示用于开启半同步复制时的调试级别,默认32 MYSQL入门 slave: MYSQL入门 MYSQL入门 Rpl_semi_sync_slave_enabled=ON表示在slave已经开始半同步复制模式 MYSQL入门 Rpl_semi_sync_slave_trace_level=32表示用于开启半同步复制时的调试级别,宋体; font-size: 14px;'>MYSQL入门 2、主从执行命令show status like '%semi%'; MYSQL入门 master MYSQL入门 MYSQL入门 Rpl_semi_sync_master_status表示主服务器使用是异步还是半同步复制 MYSQL入门 Rpl_semi_sync_master_client表示从服务器有多少个配置成半同步复制 MYSQL入门 Rpl_semi_sync_master_yes_tx表示从服务器确认成功提交的数量 MYSQL入门 Rpl_semi_sync_master_no_tx表示从服务器确认失败提交的数量 MYSQL入门 slave: MYSQL入门 MYSQL入门? MYSQL入门 Rpl_semi_sync_slave_status表示从服务器开启半同步复制 5、测试MYSQL入门 模拟slave挂掉,master等待10s仍没接收到反馈信号,则转为异步复制模式,继续执行 MYSQL入门 首先同步创建数据库aa MYSQL入门 1、slave执行stop slave;关闭主从复制 MYSQL入门 2、master在aa数据库中创建表tab1,没接收到反馈信号,等待十秒后(Rpl_semi_sync_master_timeout=1000等待超时),宋体; font-size: 14px;'>MYSQL入门 master: MYSQL入门 MYSQL入门 slave: MYSQL入门 MYSQL入门 3、master在数据库中再创建tab2,不需要等待反馈,直接执行 MYSQL入门 【当反馈超时时,master将切换到异步复制模式.此时是异步模式,不需要等待】 MYSQL入门 ? MYSQL入门 4、slave执行start slave,数据开始同步,建立tab1、tab2,反馈给master,并切换为半同步复制 MYSQL入门 MYSQL入门 5、slave执行stop slave;关闭主从复制 MYSQL入门 6、master在数据库中创建表tab3,此时需要等待10s,接收slave反馈信号;等待超时,切换为异步复制模式,宋体; font-size: 14px;'>MYSQL入门 【步骤4时,数据同步已经反馈给master,此时master已经是半同步复制模式】 MYSQL入门 6、总结MYSQL入门 半同步复制模式的性能和并发比异步复制模式低的,因为每次复制都要进行反馈,相比之下多了一个步骤. MYSQL入门 说实话我还是不太明白为什么半同步复制就可以保持数据的完整性呢?若是slave挂了,master还不是变回异步复制.和之前的全异步没什么区别.还有就是即使多了个信息反馈,但是反馈回来除了让master确认还有什么作用?假若slave挂了,没有反馈信息,那master还是没什么进一步的处理方法呀. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |