欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL在線開啟或禁用GTID模式

 更新時間:2021年11月28日 14:46:54   作者:ZhenXing_Yu  
本文詳細(xì)講解了MySQL在線開啟或禁用GTID模式的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

基本概述

我們知道MySQL有2種方式指定復(fù)制同步的方式,分別為:

  1. 基于binlog文件名及位點(diǎn)的指定方式
    - 匿名事務(wù)(Anonymous_gtid_log_event)
  2. 基于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ì)解釋

  1. 先將GTID模式的復(fù)制改為基于POS點(diǎn)的復(fù)制
  2. 設(shè)置GTID_MODE為ON_PERMISSIVE
  3. 設(shè)置GTID_MODE為OFF_PERMISSIVE
  4. 觀測GTID_OWNED狀態(tài)變量變?yōu)榭罩导皉eplication_applier_status_by_worker表中事務(wù)均轉(zhuǎn)為匿名事務(wù)
  5. 觸發(fā)FLUSH LOGS
  6. 設(shè)置GTID_MODE為OFF
  7. 設(shè)置ENFORCE_GTID_CONSISTENCY為OFF
  8. 修改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)站的支持!

相關(guān)文章

  • 淺談一下mysql數(shù)據(jù)庫底層原理

    淺談一下mysql數(shù)據(jù)庫底層原理

    這篇文章主要介紹了淺談一下mysql數(shù)據(jù)庫底層原理,介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • MySQL基礎(chǔ)入門之Case語句用法實(shí)例

    MySQL基礎(chǔ)入門之Case語句用法實(shí)例

    case語句是mysql中的一個條件語句,可以在字段中使用case語句進(jìn)行復(fù)雜的篩選以及構(gòu)造新的字段,下面這篇文章主要給大家介紹了關(guān)于MySQL基礎(chǔ)入門之Case語句用法的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • mysql下float類型使用一些誤差詳解

    mysql下float類型使用一些誤差詳解

    我想很多朋友都不怎么會在mysql中使用float類型,特別是用到金錢時我們可能會用雙精度來做,我們知道m(xù)ysql的float類型是單精度浮點(diǎn)類型不小心就會導(dǎo)致數(shù)據(jù)誤差
    2012-11-11
  • Mysql怎么存儲json格式數(shù)據(jù)詳解

    Mysql怎么存儲json格式數(shù)據(jù)詳解

    在開發(fā)中遇到存取html值的情況,并且要根據(jù)id進(jìn)行實(shí)時返回,在做的時候想到了mysql的json類型存儲,下面這篇文章主要給大家介紹了關(guān)于Mysql怎么存儲json格式數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • Linux環(huán)境下安裝mysql5.7.36數(shù)據(jù)庫教程

    Linux環(huán)境下安裝mysql5.7.36數(shù)據(jù)庫教程

    大家好,本篇文章主要講的是Linux環(huán)境下安裝mysql5.7.36數(shù)據(jù)庫教程,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • MySQL中常見的六個約束類型詳解

    MySQL中常見的六個約束類型詳解

    數(shù)據(jù)類型是為了節(jié)約內(nèi)存,提高計(jì)算, 數(shù)據(jù)約束是為了完整性(存儲關(guān)系),下面這篇文章主要給大家介紹了關(guān)于MySQL中常見的六個約束類型的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2021-09-09
  • centos7安裝mysql5.7的踩坑記錄

    centos7安裝mysql5.7的踩坑記錄

    最近在做項(xiàng)目中發(fā)現(xiàn)CentOS 7下升級MySQL5.7的一個坑,所以下面這篇文章主要給大家介紹了關(guān)于centos7安裝mysql5.7的踩坑記錄,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程詳解

    MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程詳解

    這篇文章主要介紹了MySQL對數(shù)據(jù)庫數(shù)據(jù)進(jìn)行復(fù)制的基本過程,解讀了Slave的一些相關(guān)配置,需要的朋友可以參考下
    2015-11-11
  • mysql修改用戶密碼報錯的解決方法

    mysql修改用戶密碼報錯的解決方法

    mysql 初始化時,使用臨時密碼,修改自定義密碼時,由于自定義密碼比較簡單,就出現(xiàn)了不符合密碼策略的問題,這篇文章主要介紹了mysql修改用戶密碼報錯,需要的朋友可以參考下
    2023-03-03
  • 解決mysql模糊查詢索引失效問題的幾種方法

    解決mysql模糊查詢索引失效問題的幾種方法

    我們在使用like %通配符時常常會引起索引失效的問題。本文主要介紹了常見的幾種方法,具有一定的參考價值,感興趣的可以了解一下
    2021-06-06

最新評論