MySQL在線開啟或禁用GTID模式
基本概述
我們知道MySQL有2種方式指定復(fù)制同步的方式,分別為:
- 基于binlog文件名及位點(diǎn)的指定方式
- 匿名事務(wù)(Anonymous_gtid_log_event) - 基于GTID(全局事務(wù)ID)的指定方式
- GTID事務(wù)(Gtid_log_event)
而基于GTID的方式一方面在一主多從的架構(gòu)下主從切換有著明顯優(yōu)勢外,對于日常復(fù)制異常的故障診斷方面也更為方便,從MySQL 5.7.6之后便開始支持動態(tài)開啟和關(guān)閉GTID模式,其參數(shù)GTID_MODE有以下取值
- OFF - 只允許匿名事務(wù)被復(fù)制同步
- OFF_PERMISSIVE - 新產(chǎn)生的事務(wù)都是匿名事務(wù),但也允許有GTID事務(wù)被復(fù)制同步
- ON_PERMISSIVE - 新產(chǎn)生的都是GTID事務(wù),但也允許有匿名事務(wù)被復(fù)制同步
- ON - 只允許GTID事務(wù)被復(fù)制同步
在線開啟GTID
1. 設(shè)置GTID校驗(yàn)ENFORCE_GTID_CONSISTENCY為WARN
該操作的目的是允許在主庫執(zhí)行的SQL語句違反GTID一致性校驗(yàn),且只在主庫的錯誤日志中輸出warning級別日志以作提醒,目的是為了考慮如果復(fù)制方式改為GTID模式后應(yīng)用程序不會因?yàn)镚TID的一些限制導(dǎo)致異常報錯,
如:使用CREATE TABLE AS SELECT語法在GTID模式下不支持,而ENFORCE_GTID_CONSISTENCY設(shè)置為WARN時,只會在錯誤日志提示,不會直接報錯,
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = WARN;
2. 設(shè)置GTID校驗(yàn)ENFORCE_GTID_CONSISTENCY為ON
觀測一段時間(嚴(yán)謹(jǐn)?shù)那闆r可能觀測一天以上),確認(rèn)上一個步驟未在錯誤日志中出現(xiàn)相關(guān)Warning信息后,正式開啟GTID一致性校驗(yàn),當(dāng)設(shè)置為ON后,如果再執(zhí)行CREATE TABLE AS SELECT語句則會直接報錯
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = ON;
3. 設(shè)置GTID_MODE為OFF_PERMISSIVE
該操作是一個過渡屬性,表示新產(chǎn)生的事務(wù)依舊是匿名事務(wù),但也允許有GTID事務(wù)被復(fù)制同步
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.GTID_MODE = OFF_PERMISSIVE;
4. 設(shè)置GTID_MODE為ON_PERMISSIVE
該操作依舊是一個過渡屬性,而其表示的則是新產(chǎn)生的都是GTID事務(wù),但也允許有匿名事務(wù)被復(fù)制
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.GTID_MODE = ON_PERMISSIVE;
5. (關(guān)鍵點(diǎn))確保匿名事務(wù)回放完畢
該步驟的目的是確保在正式轉(zhuǎn)換為完整的GTID模式前,老的匿名事務(wù)均以被回放完畢,確保GTID_MODE設(shè)置為ON時,不會因?yàn)闅埩舻哪涿聞?wù)導(dǎo)致復(fù)制同步報錯,有以下2種方式進(jìn)行校驗(yàn)
## 該操作僅在從庫執(zhí)行即可 ## 方式1:確保該狀態(tài)值輸出的匿名事務(wù)數(shù)顯示為0(注意:只要出現(xiàn)過0即可表示已經(jīng)轉(zhuǎn)換完成,即使后續(xù)該狀態(tài)值從0變?yōu)榱舜笥?的值也不影響) SHOW STATUS LIKE 'ONGOING_ANONYMOUS_TRANSACTION_COUNT'; ## 在從庫上多次執(zhí)行該語句 ## 方式2: 查詢該視圖中LAST_SEEN_TRANSACTION可以觀測當(dāng)前同步的事務(wù)是否還存在ANONYMOUS事務(wù) select * from performance_schema.replication_applier_status_by_worker;
確保匿名事務(wù)數(shù)為0
確?;胤啪€程回放的事務(wù)都已是GTID事務(wù)
6. 觸發(fā)一輪日志切換FLUSH LOGS
該操作的目的是為了在主庫觸發(fā)binlog的輪換,使新生成的binlog都是包含GTID的事務(wù)(防止一個binlog中包含2種類型的事務(wù)日志)
## 該操作僅在主庫執(zhí)行即可 FLUSH LOGS;
7. 正式開啟GTID_MODE為ON
正式開啟GTID
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.GTID_MODE = ON; SELECT @@GTID_MODE,@@ENFORCE_GTID_CONSISTENCY;
8. 修改配置文件確保GTID參數(shù)持久化
在my.cnf配置文件中增加GTID參數(shù),確保重啟不會失效,該操作也可在第一步進(jìn)行
## 該操作在主從庫均執(zhí)行 gtid-mode = ON enforce-gtid-consistency = 1
9. 修改復(fù)制模式為GTID方式
將復(fù)制模式從基于POS點(diǎn)改為基于GTID
## 停止復(fù)制 STOP SLAVE; ## 修改為GTID模式 CHANGE MASTER TO MASTER_AUTO_POSITION = 1; ## 開啟復(fù)制 START SLAVE; ## 觀測復(fù)制同步狀態(tài) SHOW SLAVE STATUS\G
在線關(guān)閉GTID
方式類似于在線開啟GTID的逆向操作,以下只寫出步驟和具體命令,不做詳細(xì)解釋
- 先將GTID模式的復(fù)制改為基于POS點(diǎn)的復(fù)制
- 設(shè)置GTID_MODE為ON_PERMISSIVE
- 設(shè)置GTID_MODE為OFF_PERMISSIVE
- 觀測GTID_OWNED狀態(tài)變量變?yōu)榭罩导皉eplication_applier_status_by_worker表中事務(wù)均轉(zhuǎn)為匿名事務(wù)
- 觸發(fā)FLUSH LOGS
- 設(shè)置GTID_MODE為OFF
- 設(shè)置ENFORCE_GTID_CONSISTENCY為OFF
- 修改my.cnf配置文件中GTID相關(guān)參數(shù)為OFF
1. 將復(fù)制改為基于POS點(diǎn)方式
stop slave; show slave status\G ## 取show slave status\G中的Master_Log_File和Exec_Master_Log_Pos填入 CHANGE MASTER TO MASTER_AUTO_POSITION = 0, MASTER_LOG_FILE='mysql-bin.000017', MASTER_LOG_POS=224126137; start slave; show slave status\G
2. 設(shè)置GTID_MODE為ON_PERMISSIVE
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.GTID_MODE = ON_PERMISSIVE;
3. 設(shè)置GTID_MODE為OFF_PERMISSIVE
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.GTID_MODE = OFF_PERMISSIVE;
4. (關(guān)鍵點(diǎn))確保GTID事務(wù)回放完畢
觀測GTID_OWNED狀態(tài)變量變?yōu)榭罩导皉eplication_applier_status_by_worker表中事務(wù)均轉(zhuǎn)為匿名事務(wù)
## 該操作在從庫執(zhí)行即可 SELECT @@GLOBAL.GTID_OWNED; select * from performance_schema.replication_applier_status_by_worker;
5. 觸發(fā)FLUSH LOGS
## 該操作在主庫執(zhí)行即可 FLUSH LOGS;
6. 設(shè)置GTID_MODE為OFF
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.GTID_MODE = OFF;
7. 設(shè)置ENFORCE_GTID_CONSISTENCY為OFF
## 該操作在主從庫均執(zhí)行 SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = OFF;
8. 修改my.cnf配置文件中GTID相關(guān)參數(shù)為OFF
## 該操作在主從庫均執(zhí)行 gtid-mode = OFF enforce-gtid-consistency = 1
命令簡版
1. 在線開啟GTID
自行判斷命令在主庫還是從庫執(zhí)行
SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = WARN; SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = ON; SET @@GLOBAL.GTID_MODE = OFF_PERMISSIVE; SET @@GLOBAL.GTID_MODE = ON_PERMISSIVE; SHOW STATUS LIKE 'ONGOING_ANONYMOUS_TRANSACTION_COUNT'; select * from performance_schema.replication_applier_status_by_worker; FLUSH LOGS; SET @@GLOBAL.GTID_MODE = ON; ## 配置文件修改 gtid-mode = ON enforce-gtid-consistency = 1 ## 將復(fù)制模式從基于POS點(diǎn)改為基于GTID STOP SLAVE; CHANGE MASTER TO MASTER_AUTO_POSITION = 1; START SLAVE; SHOW SLAVE STATUS\G
2. 在線關(guān)閉GTID
自行判斷命令在主庫還是從庫執(zhí)行
stop slave; show slave status\G ## 取show slave status\G中的Master_Log_File和Exec_Master_Log_Pos填入 CHANGE MASTER TO MASTER_AUTO_POSITION = 0, MASTER_LOG_FILE='mysql-bin.000017', MASTER_LOG_POS=224126137; start slave; show slave status\G SET @@GLOBAL.GTID_MODE = ON_PERMISSIVE; SET @@GLOBAL.GTID_MODE = OFF_PERMISSIVE; SELECT @@GLOBAL.GTID_OWNED; select * from performance_schema.replication_applier_status_by_worker; FLUSH LOGS; SET @@GLOBAL.GTID_MODE = OFF; SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = OFF; ## 修改my.cnf配置文件中GTID相關(guān)參數(shù)為OFF gtid-mode = OFF enforce-gtid-consistency = 1
參考鏈接
https://dev.mysql.com/doc/refman/5.7/en/replication-mode-change-online.html
https://dev.mysql.com/doc/refman/5.7/en/replication-mode-change-online-enable-gtids.html
https://dev.mysql.com/doc/refman/5.7/en/replication-mode-change-online-disable-gtids.html
以上所述是小編給大家介紹的MySQL在線開啟或禁用GTID模式,希望對大家有所幫助。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- MySQL gtid的具體使用
- MySQL主從復(fù)制基于binlog與GTID詳解
- MySQL基于GTID主從搭建
- MySQL復(fù)制之GTID復(fù)制的具體使用
- MySQL主從復(fù)制之GTID模式詳細(xì)介紹?
- MySQL GTID全面總結(jié)
- MYSQL數(shù)據(jù)庫GTID實(shí)現(xiàn)主從復(fù)制實(shí)現(xiàn)(超級方便)
- Mysql GTID Mha配置方法
- 詳解MySQL主從復(fù)制實(shí)戰(zhàn) - 基于GTID的復(fù)制
- MySQL9.1.0實(shí)現(xiàn)GTID模式的項(xiàng)目實(shí)踐
相關(guān)文章
MySQL基礎(chǔ)入門之Case語句用法實(shí)例
case語句是mysql中的一個條件語句,可以在字段中使用case語句進(jìn)行復(fù)雜的篩選以及構(gòu)造新的字段,下面這篇文章主要給大家介紹了關(guān)于MySQL基礎(chǔ)入門之Case語句用法的相關(guān)資料,需要的朋友可以參考下2022-08-08Linux環(huán)境下安裝mysql5.7.36數(shù)據(jù)庫教程
大家好,本篇文章主要講的是Linux環(huán)境下安裝mysql5.7.36數(shù)據(jù)庫教程,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程詳解
這篇文章主要介紹了MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程,解讀了Slave的一些相關(guān)配置,需要的朋友可以參考下2015-11-11