婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL GTID全面總結

MySQL GTID全面總結

熱門標簽:武漢網絡外呼系統服務商 電話外呼系統改號 地圖標注費用是多少 曲靖移動外呼系統公司 啥是企業400電話辦理 怎樣在地圖標注銷售區域 南昌三維地圖標注 百應電話機器人優勢 外呼系統打電話上限是多少

01 GTID簡介

      GTID,全稱Global transaction identifiers,也稱之為全局事務ID。MySQL-5.6.2開始支持,MySQL-5.6.10后完善,GTID 分成兩部分,一部分是服務的UUid,UUID保存在mysql數據目錄的auto.cnf文件中,
這是一個非常重要的文件,不能刪除,這一部分是不會變的。下面是一個uuid的值舉例:

[root@dev01 mysql]# cat auto.cnf 
[auto]
server-uuid=ac1ebad0-ef76-11e7-872b-080027a03bb6

    另外一部分就是事務ID了,隨著事務的增加,值依次遞增。也就是說,GTID實際上是由UUID+TID組成的。其中UUID是一個MySQL實例的唯一標識。TID代表了該實例上已經提交的事務數量。如下所示為一個GTID的例子:

3db33b36-0e51-409f-a61d-c99756e90155:1-14

02 GTID工作原理

1、master更新數據時,會在事務前產生GTID,一同記錄到binlog日志中。
2、slave端的i/o 線程將變更的binlog,寫入到本地的relay log中。
3、sql線程從relay log中獲取GTID,然后對比slave端的binlog是否有記錄。
4、如果有記錄,說明該GTID的事務已經執行,slave會忽略。
5、如果沒有記錄,slave就會從relay log中執行該GTID的事務,并記錄到binlog。
6、在解析過程中會判斷是否有主鍵,如果沒有就用二級索引,如果沒有就用全部掃描。

03 GTID的優缺點

優點:

1.一個事務對應一個唯一GTID,一個GTID在一個服務器上只會執行一次
2.GTID是用來代替傳統復制的方法,GTID復制與普通復制模式的最大不同就是不需要指定二進制文件名和位置
3.減少手工干預和降低服務故障時間,當主機掛了之后通過軟件從眾多的備機中提升一臺備機為主機

缺點:

1.不支持非事務引擎
2.不支持create table ... select 語句復制(主庫直接報錯)
原理:( 會生成兩個sql,一個是DDL創建表SQL,一個是insert into 插入數據的sql。
由于DDL會導致自動提交,所以這個sql至少需要兩個GTID,但是GTID模式下,只能給這個sql生成一個GTID )
3.不允許一個SQL同時更新一個事務引擎表和非事務引擎表
4.開啟GTID需要重啟(5.7除外)
5.對于create temporary table 和 drop temporary table語句不支持
6.不支持sql_slave_skip_counter

04 測試環境搭建

 節點:
server1   192.168.197.128  3306   Master
server2   192.168.197.137  3306   Slave
server3   192.168.197.136  3306   Slave

開啟GTID需要啟用這三個參數:

gtid_mode = on

enforce_gtid_consistency = 1

log_slave_updates   = 1

搭建測試環境的步驟如下:

1.在主節點上創建復制用戶,開啟主節點的GTID選項;

mysql> grant replication slave on *.* to 'repluser'@'%' identified by '123456';
Query OK, 0 rows affected, 1 warning (0.00 sec)

2.從節點上進行change master to操作,搭建主從,如下:

mysql> change master to 
    -> master_host='192.168.197.128',
    -> master_user='repluser',
    -> master_password='123456',
    -> master_port=3306,
    -> master_auto_position=1;
Query OK, 0 rows affected, 2 warnings (0.01 sec)

3.搭建成功后,在主節點197.128上查看從節點是否加入:

mysql> show slave hosts;
+-----------+------+------+-----------+--------------------------------------+
| Server_id | Host | Port | Master_id | Slave_UUID              |
+-----------+------+------+-----------+--------------------------------------+
|     3 |   | 3306 |     | 969488f5-c486-11e8-adb7-000c29bf2c97 |
|     2 |   | 3306 |     | bb874065-c485-11e8-8b52-000c2934472e |
+-----------+------+------+-----------+--------------------------------------+
 rows in set (. sec)

查看連接:

mysql> show processlist;
+----+----------+------------------+------+------------------+------+---------------------------------------------------------------+------------------+
| Id | User   | Host       | db  | Command     | Time | State                             | Info       |
+----+----------+------------------+------+------------------+------+---------------------------------------------------------------+------------------+
|  | root   | localhost    | NULL | Query      |  0 | starting                           | show processlist |
| 3 | repluser | work_NAT_4:60051 | NULL | Binlog Dump GTID | | Master has sent all binlog to slave; waiting for more updates | NULL       |
|  | repluser | work_NAT_5: | NULL | Binlog Dump GTID | 5970 | Master has sent all binlog to slave; waiting for more updates | NULL       |
+----+----------+------------------+------+------------------+------+---------------------------------------------------------------+------------------+
 rows in set (. sec)

4.三臺測試環境的UUID分別是:

197.128
mysql> select @@server_uuid;
+--------------------------------------+
| @@server_uuid            |
+--------------------------------------+
| bd0d-8691-11e8-afd6-4c3e51db5828 |
+--------------------------------------+
 row in set (0.00 sec)

197.137
mysql> select @@server_uuid;
+--------------------------------------+
| @@server_uuid            |
+--------------------------------------+
| bb874065-c485-11e8-8b52-000c2934472e |
+--------------------------------------+
 row in set (0.00 sec)

197.136
mysql> select @@server_uuid;
+--------------------------------------+
| @@server_uuid            |
+--------------------------------------+
| f5-c486-11e8-adb7-000c29bf2c97 |
+--------------------------------------+
 row in set (0.00 sec)

05 開始測試

測試環境主要分為以下幾個方面:

a.測試復制的故障轉移

b.復制錯誤跳過

1 測試復制的故障轉移

先來看看測試復制的故障轉移:

(1)首先將server 3的復制過程停掉

mysql> stop slave;
Query OK, 0 rows affected (0.01 sec)

(2)在server 1上創建一些數據

mysql> create table yyy.a(id int);
Query OK, 0 rows affected (0.03 sec)

mysql> create table yyy.b(id int);
Query OK, 0 rows affected (0.02 sec)

mysql> create table yyy.c(id int);
Query OK, 0 rows affected (0.02 sec)

(3)在另外兩臺上面查看數據結果:

server 
mysql> show tables from yyy;
+---------------+
| Tables_in_yyy |
+---------------+
| a       |
| b       |
| c       |
+---------------+
 rows in set (0.00 sec)

server 
mysql> show tables from yyy;
Empty set (0.00 sec)

(4)此時可以發現,server 2 的數據相比較server 3,它的數據比較新,此時停止server 1,模擬主服務器宕機:

[root@work_NAT_1 init.d]# service mysqld stop
Shutting down MySQL............              [ OK ]

(5)此時我們發現其他兩個節點已經不能訪問server 1了

mysql> show slave status\G
*************************** 1. row ***************************
        Slave_IO_State: Reconnecting after a failed master event read
         Master_Host: 192.168.197.128
         Master_User: repluser
         Master_Port: 3306
        Connect_Retry: 60
       Master_Log_File: mysql-bin.000006
     Read_Master_Log_Pos: 1364
        Relay_Log_File: mysql-relay-bin.000004
        Relay_Log_Pos: 1569
    Relay_Master_Log_File: mysql-bin.000006
       Slave_IO_Running: Connecting
      Slave_SQL_Running: Yes
     Exec_Master_Log_Pos: 1364
       Relay_Log_Space: 2337 
        Master_SSL_Key: 
    Seconds_Behind_Master: NULL
Master_SSL_Verify_Server_Cert: No
        Last_IO_Errno: 2003
        Last_IO_Error: error reconnecting to master 'repluser@192.168.197.128:3306' - retry-time: 60 retries: 1
        Last_SQL_Errno: 0

(6)我們需要設置server 2為server 3的主庫,因為server 2的數據比較新。此時如果采用以前的辦法,需要計算之前主庫的log_pos和當前要設置成主庫的log_pos,很有可能出錯。所以出現了一些高可用性的工具如MHA,MMM等解決問題。

在MySQL5.6之后,很簡單的解決了這個難題。因為同一事務的GTID在所有節點上的值一致,那么根據server3當前停止點的GTID就能定位到server2上的GTID,所以直接在server3上執行change即可:

mysql> change master to 
  -> master_host='192.168.197.137',
  -> master_user='repluser',
  -> master_password='123456',
  -> master_port=,
  -> master_auto_position=;
Query OK, rows affected, warnings (0.01 sec)

(7)此時查看server 3上的數據,可以發現,數據已經同步過來了;

2 復制錯誤跳過

    上面的測試中,最終的結果是server 2是主節點,server 3是從節點,下面我們來驗證復制錯誤跳過的辦法。

(1)首先我們在從節點上執行一個drop的語句,讓兩邊的數據不一致,如下:

mysql> show databases;
+--------------------+
| Database      |
+--------------------+
| information_schema |
| DBAs        |
| customer      |
| inc_db       |
| mysql       |
| performance_schema |
| sys        |
| testdb       |
| yeyz        |
| yyy        |
+--------------------+
 rows in set (. sec)

mysql> drop database yyy;
Query OK, rows affected (. sec)

mysql> show databases;
+--------------------+
| Database      |
+--------------------+
| information_schema |
| DBAs        |
| customer      |
| inc_db       |
| mysql       |
| performance_schema |
| sys        |
| testdb       |
| yeyz        |
+--------------------+
 rows in set (. sec)

(2)然后我們在server 2上執行drop database yyy的操作,如下:

mysql> drop database yyy;
Query OK, 3 rows affected (0.02 sec)

(3)此時我們看到server 3上已經出現了主從不同步的錯誤警告,因為它上面并沒有yyy的數據庫(前一步已經刪除),錯誤情況如下;

mysql> show slave status\G
*************************** . row ***************************
        Slave_IO_State: Waiting for master to send event
         Master_Host: 192.168.197.137
         Master_User: repluser
         Master_Port: 
        Connect_Retry: 
       Master_Log_File: mysql-bin.
     Read_Master_Log_Pos: 
        Relay_Log_File: mysql-relay-bin.
        Relay_Log_Pos: 
    Relay_Master_Log_File: mysql-bin.
       Slave_IO_Running: Yes
      Slave_SQL_Running: No
          Last_Errno: 
          Last_Error: Error 'Can't drop database 'yyy'; database doesn't exist' on query. Default database: 'yyy'. Query: 'drop database yyy'
         Skip_Counter: 
     Exec_Master_Log_Pos: 
       Relay_Log_Space: 
        Last_SQL_Error: Error 'Can't drop database 'yyy'; database doesn't exist' on query. Default database: 'yyy'. Query: 'drop database yyy'
 Replicate_Ignore_Server_Ids: 
       Master_Server_Id: 
         Master_UUID: bb874065-c485-e8-b52-c2934472e
       Master_Info_File: mysql.slave_master_info
      Retrieved_Gtid_Set: bd0d--e8-afd6-c3e51db5828:-,
bb874065-c485-e8-b52-c2934472e:
      Executed_Gtid_Set: db33b36-e51-f-a61d-c99756e90155:-,
bd0d--e8-afd6-c3e51db5828:-,
f5-c486-e8-adb7-c29bf2c97:
        Auto_Position: 
     Replicate_Rewrite_DB: 
         Channel_Name: 
      Master_TLS_Version: 
 row in set (0.00 sec)

(4)當我們使用傳統的方法來跳過這個錯誤的時候,會提示出GTID模式下不被允許,如下:

mysql> set global sql_slave_skip_counter=;
ERROR (HY000): sql_slave_skip_counter can not be set when the server is running with @@GLOBAL.GTID_MODE = ON. Instead, for each transaction that you want to skip, generate an empty transaction with the same GTID as the transaction

那么這種方式下應該如何跳過這個錯誤呢?

(5)因為我們是通過GTID來進行復制的,也需要跳過這個事務從而繼續復制,這個事務可以到主上的binlog里面查看:因為不知道找哪個GTID上出錯,所以也不知道如何跳過哪個GTID。但是我們可以在show slave status里的信息里找到在執行Master里的POS:2012,也就是上述第(3)步第18行代碼。現在我們拿著這個pos:2012去server 2的日志里面找,可以發現如下信息:

# at 2012
#190305 20:59:07 server id 2 end_log_pos 2073 GTID  last_committed=9    sequence_number=10   rbr_only=no
SET @@SESSION.GTID_NEXT= 'bb874065-c485-11e8-8b52-000c2934472e:1'/*!*/;
# at 2073
#190305 20:59:07 server id 2 end_log_pos 2158 Query  thread_id=3   exec_time=0   error_code=0
SET TIMESTAMP=/*!*/;
drop database yyy
/*!*/;

(6)我們可以看到GTID_NEXT的值是

,然后我們通過下面的方法來重新恢復主從復制:

mysql> stop slave;
Query OK, rows affected (0.00 sec)

mysql> set session gtid_next='bb874065-c485-11e8-8b52-000c2934472e:1';
Query OK, rows affected (0.00 sec)

mysql> begin;
Query OK, rows affected (0.00 sec)

mysql> commit;
Query OK, rows affected (0.01 sec)

mysql> set session gtid_next=automatic;
Query OK, rows affected (0.00 sec)

mysql> start slave;
Query OK, rows affected (0.00 sec)

mysql> show slave status\G
*************************** 1. row ***************************
        Slave_IO_State: Waiting for master to send event
         Master_Host: 192.168.197.137
         Master_User: repluser
         Master_Port: 3306
        Connect_Retry: 60
       Master_Log_File: mysql-bin.000002
     Read_Master_Log_Pos: 2158
        Relay_Log_File: mysql-relay-bin.000003
        Relay_Log_Pos: 478
    Relay_Master_Log_File: mysql-bin.000002
       Slave_IO_Running: Yes
      Slave_SQL_Running: Yes
     Exec_Master_Log_Pos: 2158
       Relay_Log_Space: 1527
       Until_Condition: None
       Master_Server_Id: 2
         Master_UUID: bb874065-c485-11e8-8b52-000c2934472e
       Master_Info_File: mysql.slave_master_info
          SQL_Delay: 0
     SQL_Remaining_Delay: NULL
   Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
      Master_Retry_Count: 
      Retrieved_Gtid_Set: bd0d-8691-11e8-afd6-4c3e51db5828:-7,
bb874065-c485-11e8-8b52-000c2934472e:
      Executed_Gtid_Set: db33b36-0e51-409f-a61d-c99756e90155:-14,
bd0d-8691-11e8-afd6-4c3e51db5828:-7,
f5-c486-11e8-adb7-000c29bf2c97:,
bb874065-c485-11e8-8b52-000c2934472e:
        Auto_Position: 
     Replicate_Rewrite_DB: 
         Channel_Name: 
      Master_TLS_Version: 
 row in set (0.00 sec)

以上就是MySQL GTID全面總結的詳細內容,更多關于MySQL GTID的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • MYSQL數據庫GTID實現主從復制實現(超級方便)
  • MySQL5.6 GTID模式下同步復制報錯不能跳過的解決方法
  • Mysql GTID Mha配置方法
  • MySQL5.7不停業務將傳統復制變更為GTID復制的實例
  • 詳解MySQL主從復制實戰 - 基于GTID的復制
  • MySQL 5.6 GTID新特性實踐
  • MySQL5.6基于GTID的主從復制
  • 在MySQL中使用GTIDs復制協議和中斷協議的教程
  • MySQL是如何實現主備同步
  • 關于mysql主備切換canal出現的問題解決
  • 基于mysql+mycat搭建穩定高可用集群負載均衡主備復制讀寫分離操作
  • MySQL GTID主備不一致的修復方案

標簽:黑河 資陽 滄州 錦州 荊州 吉林 甘南 隨州

巨人網絡通訊聲明:本文標題《MySQL GTID全面總結》,本文關鍵詞  MySQL,GTID,全面,總結,MySQL,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL GTID全面總結》相關的同類信息!
  • 本頁收集關于MySQL GTID全面總結的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日本特黄久久久高潮| 国产成人8x视频一区二区| 黄色成人免费在线| 99热国产精品| 欧美电影免费提供在线观看| 亚洲欧美日韩中文字幕一区二区三区 | 日韩黄色免费电影| 国产成人在线免费| 日韩一区二区电影在线| 亚洲综合偷拍欧美一区色| 国内外成人在线视频| 欧美午夜电影在线播放| 国产精品人妖ts系列视频| 日本欧美一区二区在线观看| 91亚洲精品一区二区乱码| 精品美女被调教视频大全网站| 一区二区三区日韩精品视频| 国产成人免费在线视频| 日韩精品最新网址| 五月激情综合色| 欧美视频一区二区三区| 亚洲天堂成人在线观看| 国产精选一区二区三区| 日韩三级视频在线看| 91麻豆国产福利精品| 久久只精品国产| 日韩有码一区二区三区| 欧美电影一区二区三区| 日本不卡一区二区| 4438x亚洲最大成人网| 亚洲大片免费看| 欧美日韩国产经典色站一区二区三区 | 综合久久久久久久| 成人一级黄色片| 日本一区二区电影| 国产91精品久久久久久久网曝门| 日韩欧美色综合网站| 日本sm残虐另类| 制服丝袜中文字幕一区| 奇米精品一区二区三区在线观看 | 午夜亚洲国产au精品一区二区| 99精品久久只有精品| 中文字幕一区三区| 一本色道久久综合亚洲aⅴ蜜桃| 中文字幕一区二区三区色视频| 99精品久久久久久| 一区二区三区四区国产精品| 欧美理论片在线| 老司机免费视频一区二区| 精品成人一区二区三区| 成人丝袜18视频在线观看| 综合电影一区二区三区 | 色综合天天综合狠狠| 一区二区三区不卡在线观看| 欧美综合欧美视频| 喷水一区二区三区| 中文字幕免费在线观看视频一区| kk眼镜猥琐国模调教系列一区二区| 日韩伦理av电影| 56国语精品自产拍在线观看| 蜜臀a∨国产成人精品| 亚洲精品一区在线观看| av网站免费线看精品| 亚洲午夜久久久久久久久电影院| 欧美年轻男男videosbes| 国产在线精品一区二区夜色 | 亚洲www啪成人一区二区麻豆| 日韩免费观看高清完整版 | 国产在线观看免费一区| 亚洲乱码国产乱码精品精可以看 | 国产精品免费丝袜| 欧美精品在线观看一区二区| 国产精品性做久久久久久| 亚洲欧美一区二区久久 | 91精品欧美福利在线观看| 成人精品小蝌蚪| 午夜激情一区二区| 亚洲国产成人一区二区三区| 欧美日韩美女一区二区| 国产精品99久| 免费在线观看视频一区| 亚洲精品综合在线| 国产三区在线成人av| 欧美一区二区三区在线观看| eeuss影院一区二区三区| 精品一区二区三区在线播放视频 | 欧美三级中文字幕| 99精品国产99久久久久久白柏| 麻豆精品在线观看| 亚洲成人777| 亚洲欧美激情一区二区| 久久久不卡网国产精品一区| 欧美亚洲国产一区二区三区 | 国产精品一区二区果冻传媒| 日韩精品视频网站| 亚洲美女淫视频| 日本一区二区高清| 久久久噜噜噜久久中文字幕色伊伊| 欧美日韩你懂的| 色先锋资源久久综合| 成人高清免费观看| 久久国产精品99久久久久久老狼| 亚洲曰韩产成在线| 亚洲丝袜另类动漫二区| 欧美高清在线一区二区| 国产午夜亚洲精品羞羞网站| 26uuu另类欧美亚洲曰本| 日韩一区二区在线免费观看| 欧美日韩国产综合一区二区| 欧美日韩一区国产| 69久久99精品久久久久婷婷| 欧美在线综合视频| 欧美日韩日本视频| 91.麻豆视频| 91精品国产一区二区三区蜜臀| 欧美日韩色一区| 欧美丰满高潮xxxx喷水动漫| 欧美日本国产一区| 欧美日韩国产综合一区二区三区| 欧美日韩一级二级| 欧美丰满少妇xxxxx高潮对白| 欧美乱妇23p| 日韩一级二级三级精品视频| 日韩亚洲国产中文字幕欧美| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 国产精品中文字幕日韩精品 | 色诱视频网站一区| 欧美色网一区二区| 337p亚洲精品色噜噜噜| 久久亚洲精品小早川怜子| 久久久亚洲国产美女国产盗摄 | 亚洲国产毛片aaaaa无费看| 性久久久久久久久久久久| 日韩电影在线一区二区| 国产一区二区三区美女| 99综合电影在线视频| 99re成人在线| 欧美精品日韩精品| 久久婷婷成人综合色| 亚洲高清在线精品| 久久se精品一区精品二区| 国产成人av一区二区| 欧美在线观看视频一区二区| 6080日韩午夜伦伦午夜伦| 国产调教视频一区| 亚洲一区二区在线免费观看视频| 日韩国产一区二| 粉嫩高潮美女一区二区三区| 欧洲另类一二三四区| 日韩一级高清毛片| 亚洲色图视频网| 久久精品国产精品青草| 91免费精品国自产拍在线不卡| 这里只有精品免费| 国产精品久久久久久久久晋中 | 亚洲欧美激情在线| 日韩av电影免费观看高清完整版在线观看 | 成人伦理片在线| 欧美疯狂做受xxxx富婆| 国产精品国产三级国产a| 日本欧美加勒比视频| 北条麻妃国产九九精品视频| 欧美电影影音先锋| 亚洲精品成a人| 国产毛片精品一区| 制服丝袜国产精品| 亚洲欧美色图小说| 国产精品亚洲第一区在线暖暖韩国| 欧美亚洲一区三区| 中文字幕亚洲成人| 国产麻豆精品久久一二三| 欧美夫妻性生活| 一区二区三区鲁丝不卡| 成人性生交大片| 久久一夜天堂av一区二区三区| 亚洲一区二区三区小说| 成人黄色a**站在线观看| 日韩精品一区二区在线观看| 亚洲伊人色欲综合网| 97国产一区二区| 国产精品青草久久| 久久精品国产77777蜜臀| 欧美日韩国产免费| 亚洲愉拍自拍另类高清精品| 91污片在线观看| 亚洲国产精品二十页| 国产成人自拍在线| 久久精品免视看| 美国精品在线观看| 日韩欧美一级二级| 蜜臀av国产精品久久久久| 欧美一区二区三区四区视频| 亚洲成人久久影院| 欧美日韩高清影院| 亚洲影视在线播放| 欧美亚洲综合网| 亚洲福中文字幕伊人影院| 欧美日韩五月天| 日韩成人精品在线观看| 欧美一区二区三级|