MySQL Group Replication(下簡稱:MGR)是MySQL官方推出的一種基于Paxos協(xié)議的狀態(tài)機(jī)復(fù)制。在MGR出現(xiàn)之前,用戶常見的MySQL高可用方式,無論怎么變化架構(gòu),本質(zhì)就是Master-Slave架構(gòu)。MySQL 5.7版本開始支持無損半同步復(fù)制(lossless semi-sync replication),從而進(jìn)一步提示數(shù)據(jù)復(fù)制的強(qiáng)一致性
?
創(chuàng)新互聯(lián)是一家專業(yè)提供承德企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為承德眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。
master事務(wù)的提交不需要經(jīng)過slave的確認(rèn),slave是否接收到master的binlog,master并不care。slave接收到master binlog后先寫relay log,最后異步地去執(zhí)行relay log中的sql應(yīng)用到自身。由于master的提交不需要確保slave relay log是否被正確接受,當(dāng)slave接受master binlog失敗或者relay log應(yīng)用失敗,master無法感知
?
?
基于傳統(tǒng)異步存在的缺陷,mysql在5.5版本推出半同步復(fù)制??梢哉f半同步復(fù)制是傳統(tǒng)異步復(fù)制的改進(jìn),在master事務(wù)的commit之前,必須確保一個(gè)slave收到relay log并且響應(yīng)給master以后,才能進(jìn)行事務(wù)的commit。但是slave對(duì)于relay log的應(yīng)用仍然是異步進(jìn)行的,原理如下圖所示:
?
?
基于傳統(tǒng)異步復(fù)制和半同步復(fù)制的缺陷——數(shù)據(jù)的一致性問題無法保證,MySQL官方在5.7.17版本正式推出組復(fù)制(MySQL Group Replication,簡稱MGR)。
?
由若干個(gè)節(jié)點(diǎn)共同組成一個(gè)復(fù)制組,一個(gè)事務(wù)的提交,必須經(jīng)過組內(nèi)大多數(shù)節(jié)點(diǎn)(N / 2 + 1)決議并通過,才能得以提交。如上圖所示,由3個(gè)節(jié)點(diǎn)組成一個(gè)復(fù)制組,Consensus層為一致性協(xié)議層,在事務(wù)提交過程中,發(fā)生組間通訊,由2個(gè)節(jié)點(diǎn)決議(certify)通過這個(gè)事務(wù),事務(wù)才能夠最終得以提交并響應(yīng)。
?
引入組復(fù)制,主要是為了解決傳統(tǒng)異步復(fù)制和半同步復(fù)制可能產(chǎn)生數(shù)據(jù)不一致的問題。組復(fù)制依靠分布式一致性協(xié)議(Paxos協(xié)議的變體),實(shí)現(xiàn)了分布式下數(shù)據(jù)的最終一致性,提供了真正的數(shù)據(jù)高可用方案(是否真正高可用還有待商榷)。其提供的多寫方案,給我們實(shí)現(xiàn)多活方案帶來了希望。
?
?
特性優(yōu)點(diǎn):
1、高一致性,基于原生復(fù)制及paxos協(xié)議的組復(fù)制技術(shù),并以插件的方式提供,提供一致數(shù)據(jù)安全保證;
2、高容錯(cuò)性,只要不是大多數(shù)節(jié)點(diǎn)壞掉就可以繼續(xù)工作,有自動(dòng)檢測機(jī)制,當(dāng)不同節(jié)點(diǎn)產(chǎn)生資源爭用沖突時(shí),不會(huì)出現(xiàn)錯(cuò)誤,按照先到者優(yōu)先原則進(jìn)行處理,并且內(nèi)置了自動(dòng)化腦裂防護(hù)機(jī)制;
3、高擴(kuò)展性,節(jié)點(diǎn)的新增和移除都是自動(dòng)的,新節(jié)點(diǎn)加入后,會(huì)自動(dòng)從其他節(jié)點(diǎn)上同步狀態(tài),直到新節(jié)點(diǎn)和其他節(jié)點(diǎn)保持一致,如果某節(jié)點(diǎn)被移除了,其他節(jié)點(diǎn)自動(dòng)更新組信息,自動(dòng)維護(hù)新的組信息;
4、高靈活性,有單主模式和多主模式,單主模式下,會(huì)自動(dòng)選主,所有更新操作都在主上進(jìn)行;多主模式下,所有server都可以同時(shí)處理更新操作。
限制:(具體可參考官方文檔說明:https://dev.mysql.com/doc/refman/5.7/en/group-replication-requirements-and-limitations.html)
1、僅支持InnoDB表,并且每張表一定要有一個(gè)主鍵,用于做write set的沖突檢測;
2、必須打開GTID特性,二進(jìn)制日志格式必須設(shè)置為ROW,用于選主與write set
3、COMMIT可能會(huì)導(dǎo)致失敗,類似于快照事務(wù)隔離級(jí)別的失敗場景
4、目前一個(gè)MGR集群最多支持9個(gè)節(jié)點(diǎn)
5、不支持外鍵于save point特性,無法做全局間的約束檢測與部分事務(wù)回滾
6、二進(jìn)制日志不支持binlog event checksum
?
?
搭建參照的官方文檔:
官方文檔:https://dev.mysql.com/doc/refman/5.7/en/group-replication.html
單主節(jié)點(diǎn)搭建地址:https://dev.mysql.com/doc/refman/5.7/en/group-replication-deploying-in-single-primary-mode.html
多主節(jié)點(diǎn)搭建基本和單主步驟一樣,只需要配置文件my.cnf額外添加,本文以下示例為單主節(jié)點(diǎn)搭建,多主節(jié)點(diǎn)搭建亦相差無幾
loose-group_replication_single_primary_mode=FALSE
loose-group_replication_enforce_update_everywhere_checks= TRUE
?
?
主機(jī)ip | 安裝服務(wù) | 權(quán)重 |
---|---|---|
192.168.142.48 | mysql server 5.7.18 | 50 |
192.168.142.49 | mysql server 5.7.18 | 40 |
192.168.142.50 | mysql server 5.7.18 | 30 |
權(quán)重:新主選舉時(shí)的優(yōu)先級(jí)參照,越大,優(yōu)先級(jí)越高
?
?
在三臺(tái)數(shù)據(jù)庫服務(wù)器上都設(shè)置:
192.168.142.48 dbtest1
192.168.142.49 dbtest2
192.168.142.50 dbtest3
?
?
配置文件介紹參照官方文檔:https://dev.mysql.com/doc/refman/5.7/en/group-replication-configuring-instances.html
# Replication Framework
server_id=1
gtid_mode=ON
enforce_gtid_consistency=ON
master_info_repository=TABLE
relay_log_info_repository=TABLE
log_bin=binlog
binlog_format=ROW
log_slave_updates=ON
binlog_checksum=NONE
transaction_write_set_extraction=XXHASH64
loose-group_replication_group_name="aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"
loose-group_replication_start_on_boot=off
loose-group_replication_local_address= "192.168.142.48:33061"
loose-group_replication_group_seeds= "192.168.142.48:33061,192.168.142.49:33061,192.168.142.50:33061"
loose-group_replication_bootstrap_group=off
loose-group_replication_member_weight=50
?
?
手動(dòng)搭建或者自動(dòng)化腳本分別在三臺(tái)主機(jī)上配置mysql實(shí)例,這里可參考MySQL單實(shí)例搭建的方法,不在贅述
?
?
1、設(shè)置復(fù)制賬號(hào)權(quán)限
SET SQL_LOG_BIN=0;
CREATE USER rpl_user@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO rpl_user@'%';
FLUSH PRIVILEGES;
SET SQL_LOG_BIN=1;
2、指定恢復(fù)渠道channel
CHANGE MASTER TO MASTER_USER='rpl_user', MASTER_PASSWORD='password' FOR CHANNEL 'group_replication_recovery';
3、安裝插件plugin和查看
INSTALL PLUGIN group_replication SONAME 'group_replication.so';
show plugins;
4、開啟組復(fù)制
# 設(shè)置group_replication_bootstrap_group為ON是為了標(biāo)示以后加入集群的服務(wù)器以這臺(tái)服務(wù)器為基準(zhǔn),以后加入的就不需要設(shè)置
SET GLOBAL group_replication_bootstrap_group=ON;
START GROUP_REPLICATION;
SET GLOBAL group_replication_bootstrap_group=OFF;
5、查看mgr的狀態(tài)
# 查詢表performance_schema.replication_group_members
select * from performance_schema.replication_group_members;
?
1、設(shè)置復(fù)制賬號(hào)權(quán)限
SET SQL_LOG_BIN=0;
CREATE USER rpl_user@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO rpl_user@'%';
FLUSH PRIVILEGES;
SET SQL_LOG_BIN=1;
2、指定恢復(fù)渠道channel
CHANGE MASTER TO MASTER_USER='rpl_user', MASTER_PASSWORD='password' FOR CHANNEL 'group_replication_recovery';
3、安裝插件plugin和查看
INSTALL PLUGIN group_replication SONAME 'group_replication.so';
show plugins;
4、開啟組復(fù)制
# 這里不再需要開啟group_replication_bootstrap_group,由于復(fù)制組已經(jīng)被創(chuàng)建了,只需要將第二個(gè)節(jié)點(diǎn)添加進(jìn)去即可
START GROUP_REPLICATION;
5、查看mgr的狀態(tài)
# 查詢表performance_schema.replication_group_members
select * from performance_schema.replication_group_members;
?
?
1、切換
STOP GROUP_REPLICATION;會(huì)根據(jù)權(quán)重重新選擇新的主master
START GROUP_REPLICATION;新加入后作為從服務(wù)器slave
?
2、相關(guān)狀態(tài)查看
1、當(dāng)前組成員列表
select * from performance_schema.replication_group_members;
2、當(dāng)前節(jié)點(diǎn)詳細(xì)日志應(yīng)用信息
select * from performance_schema.replication_group_member_stats;
3、當(dāng)前復(fù)制渠道連接信息
select * from performance_schema.replication_connection_status;
4、當(dāng)前復(fù)制渠道應(yīng)用信息
select * from performance_schema.replication_applier_status;
5、當(dāng)前主master
select a.variable_value,b.member_host,b.member_port,member_state from performance_schema.global_status a ,performance_schema.replication_group_members b where a.variable_value=b.member_id and variable_name= 'group_replication_primary_member';
?
?
?
例如原有192.168.142.48,192.168.142.49,192.168.142.50組成MGR的基礎(chǔ)上動(dòng)態(tài)新增節(jié)點(diǎn)192.168.142.51
?
1、創(chuàng)建hostname和ip的映射
在四臺(tái)數(shù)據(jù)庫服務(wù)器上都設(shè)置:
192.168.142.48 dbtest1
192.168.142.49 dbtest2
192.168.142.50 dbtest3
192.168.142.51 dbtest4
2、192.168.142.51的my.cnf配置文件和上面my.cnf保持一致,額外修改的如下
loose-group_replication_local_address= "192.168.142.51:33061"
loose-group_replication_group_seeds= "192.168.142.48:33061,192.168.142.49:33061,192.168.142.50:33061,192.168.142.51:33061"
3、創(chuàng)建數(shù)據(jù)庫實(shí)例
手動(dòng)搭建或者自動(dòng)化腳本分別在三臺(tái)主機(jī)上配置mysql實(shí)例,這里可參考MySQL單實(shí)例搭建的方法,不在贅述
4、設(shè)置復(fù)制賬號(hào)權(quán)限
SET SQL_LOG_BIN=0;
CREATE USER rpl_user@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO rpl_user@'%';
FLUSH PRIVILEGES;
SET SQL_LOG_BIN=1;
5、指定恢復(fù)渠道channel
CHANGE MASTER TO MASTER_USER='rpl_user', MASTER_PASSWORD='password' FOR CHANNEL 'group_replication_recovery';
6、安裝插件plugin和查看
INSTALL PLUGIN group_replication SONAME 'group_replication.so';
show plugins;
7、集群中已存在的節(jié)點(diǎn)配置修改group_replication_group_seeds的值
1、分別在192.168.142.48,192.168.142.49,192.168.142.50對(duì)應(yīng)節(jié)點(diǎn)服務(wù)器配置參數(shù)
set global group_replication_group_seeds="192.168.142.48:33061,192.168.142.49:33061,192.168.142.50:33061,192.168.142.51:33061";
2、將對(duì)應(yīng)參數(shù)值寫入配置文件my.cnf持久化
8、開啟組復(fù)制
# 這里不再需要開啟group_replication_bootstrap_group,由于復(fù)制組已經(jīng)被創(chuàng)建了,只需要將新增節(jié)點(diǎn)添加進(jìn)去即可
START GROUP_REPLICATION;
9、查看mgr的狀態(tài)
# 查詢表performance_schema.replication_group_members
select * from performance_schema.replication_group_members;
?
?
例如原有192.168.142.48,192.168.142.49,192.168.142.50,192.168.142.51組成MGR的基礎(chǔ)上動(dòng)態(tài)刪除節(jié)點(diǎn)192.168.142.51
1、停止192.168.142.51上組復(fù)制
STOP GROUP_REPLICATION;
slave關(guān)閉后就被移除了組成員
2、集群中剩余的節(jié)點(diǎn)配置修改group_replication_group_seeds的值
1、分別在192.168.142.48,192.168.142.49,192.168.142.50對(duì)應(yīng)節(jié)點(diǎn)服務(wù)器配置參數(shù)
set global group_replication_group_seeds="192.168.142.48:33061,192.168.142.49:33061,192.168.142.50:33061";
2、將對(duì)應(yīng)參數(shù)值寫入配置文件my.cnf持久化
3、徹底清理192.168.142.51節(jié)點(diǎn)相關(guān)組信息,配置修改group_replication_group_seeds和group_replication_local_address的值
1、在192.168.142.51對(duì)應(yīng)節(jié)點(diǎn)服務(wù)器配置參數(shù)
set global group_replication_group_seeds="";
set global group_replication_local_address="";
2、將對(duì)應(yīng)參數(shù)值寫入配置文件my.cnf持久化(添加注釋)
4、刪除插件plugin、復(fù)制賬號(hào)權(quán)限