日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL GTID全面總結(jié)

瀏覽:34日期:2023-10-04 13:46:29
01 GTID簡介

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

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

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

3db33b36-0e51-409f-a61d-c99756e90155:1-1402 GTID工作原理

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

03 GTID的優(yōu)缺點

優(yōu)點:

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

缺點:

1.不支持非事務引擎2.不支持create table ... select 語句復制(主庫直接報錯)原理:( 會生成兩個sql,一個是DDL創(chuàng)建表SQL,一個是insert into 插入數(shù)據(jù)的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 測試環(huán)境搭建

節(jié)點:server1 192.168.197.128 3306 Masterserver2 192.168.197.137 3306 Slaveserver3 192.168.197.136 3306 Slave

開啟GTID需要啟用這三個參數(shù):

gtid_mode = on

enforce_gtid_consistency = 1

log_slave_updates = 1

搭建測試環(huán)境的步驟如下:

1.在主節(jié)點上創(chuàng)建復制用戶,開啟主節(jié)點的GTID選項;

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

2.從節(jié)點上進行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.搭建成功后,在主節(jié)點197.128上查看從節(jié)點是否加入:

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.三臺測試環(huán)境的UUID分別是:

197.128mysql> select @@server_uuid;+--------------------------------------+| @@server_uuid |+--------------------------------------+| bd0d-8691-11e8-afd6-4c3e51db5828 |+--------------------------------------+ row in set (0.00 sec)197.137mysql> select @@server_uuid;+--------------------------------------+| @@server_uuid |+--------------------------------------+| bb874065-c485-11e8-8b52-000c2934472e |+--------------------------------------+ row in set (0.00 sec)197.136mysql> select @@server_uuid;+--------------------------------------+| @@server_uuid |+--------------------------------------+| f5-c486-11e8-adb7-000c29bf2c97 |+--------------------------------------+ row in set (0.00 sec)05 開始測試

測試環(huán)境主要分為以下幾個方面:

a.測試復制的故障轉(zhuǎn)移

b.復制錯誤跳過

1 測試復制的故障轉(zhuǎn)移

先來看看測試復制的故障轉(zhuǎn)移:

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

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

(2)在server 1上創(chuàng)建一些數(shù)據(jù)

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)在另外兩臺上面查看數(shù)據(jù)結(jié)果:

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)此時可以發(fā)現(xiàn),server 2 的數(shù)據(jù)相比較server 3,它的數(shù)據(jù)比較新,此時停止server 1,模擬主服務器宕機:

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

(5)此時我們發(fā)現(xiàn)其他兩個節(jié)點已經(jīng)不能訪問server 1了

mysql> show slave statusG*************************** 1. row ***************************Slave_IO_State: Reconnecting after a failed master event read Master_Host: 192.168.197.128 Master_User: repluser Master_Port: 3306Connect_Retry: 60 Master_Log_File: mysql-bin.000006 Read_Master_Log_Pos: 1364Relay_Log_File: mysql-relay-bin.000004Relay_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: NULLMaster_SSL_Verify_Server_Cert: NoLast_IO_Errno: 2003Last_IO_Error: error reconnecting to master ’repluser@192.168.197.128:3306’ - retry-time: 60 retries: 1Last_SQL_Errno: 0

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

在MySQL5.6之后,很簡單的解決了這個難題。因為同一事務的GTID在所有節(jié)點上的值一致,那么根據(jù)server3當前停止點的GTID就能定位到server2上的GTID,所以直接在server3上執(zhí)行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上的數(shù)據(jù),可以發(fā)現(xiàn),數(shù)據(jù)已經(jīng)同步過來了;

2 復制錯誤跳過

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

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

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上執(zhí)行drop database yyy的操作,如下:

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

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

mysql> show slave statusG*************************** . 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)當我們使用傳統(tǒng)的方法來跳過這個錯誤的時候,會提示出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來進行復制的,也需要跳過這個事務從而繼續(xù)復制,這個事務可以到主上的binlog里面查看:因為不知道找哪個GTID上出錯,所以也不知道如何跳過哪個GTID。但是我們可以在show slave status里的信息里找到在執(zhí)行Master里的POS:2012,也就是上述第(3)步第18行代碼?,F(xiàn)在我們拿著這個pos:2012去server 2的日志里面找,可以發(fā)現(xiàn)如下信息:

# at 2012#190305 20:59:07 server id 2 end_log_pos 2073 GTID last_committed=9 sequence_number=10 rbr_only=noSET @@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=0SET 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 statusG*************************** 1. row ***************************Slave_IO_State: Waiting for master to send event Master_Host: 192.168.197.137 Master_User: repluser Master_Port: 3306Connect_Retry: 60 Master_Log_File: mysql-bin.000002 Read_Master_Log_Pos: 2158Relay_Log_File: mysql-relay-bin.000003Relay_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全面總結(jié)的詳細內(nèi)容,更多關(guān)于MySQL GTID的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲婷婷免费| 视频一区二区三区在线| 欧美精品91| 久久国产精品美女| 国产999精品在线观看| 欧美色图国产精品| 免费观看在线综合| 国产亚洲电影| 国产精品国码视频| 日韩电影免费网站| 在线一区视频| 国产欧美三级| 欧美精品高清| 天使萌一区二区三区免费观看| 亚洲美女久久| 精品久久久久中文字幕小说| 欧美成人高清| 日本电影久久久| 麻豆成人在线观看| 欧美日韩免费观看一区=区三区| 天堂久久av| 高清av一区| 蜜桃久久av一区| 国产精品sm| 午夜精品婷婷| 欧美极品中文字幕| 怡红院精品视频在线观看极品| 久久国内精品视频| 国产99久久| 国产欧美一区二区三区国产幕精品 | 精品国产乱码久久久久久樱花| 99久久久久久中文字幕一区| 亚洲精品亚洲人成在线观看| 美女一区网站| 日韩欧美中文字幕在线视频| se01亚洲视频| 最新国产精品视频| 亚洲精品福利电影| 日韩精品久久久久久| 91精品一区二区三区综合在线爱| 日本久久一区| 亚洲韩日在线| 美女精品一区二区| 免费人成黄页网站在线一区二区| 国产精品蜜芽在线观看| 日产欧产美韩系列久久99| 性欧美videohd高精| 国产乱人伦丫前精品视频 | 亚洲精品高潮| 色综合五月天| 日韩精品亚洲aⅴ在线影院| 91精品韩国| 国产亚洲欧美日韩精品一区二区三区| 日韩一级不卡| av在线最新| 日韩精品电影一区亚洲| 亚洲成人精品| 久久精品理论片| 91精品国产自产精品男人的天堂 | 日本电影久久久| aa亚洲婷婷| 欧美特黄一区| 99精品小视频| 国产日韩欧美一区二区三区在线观看 | 中文字幕中文字幕精品| 国产96在线亚洲| 欧美在线黄色| 日韩午夜免费| 亚洲二区在线| 中文字幕一区久| 麻豆精品av| 日本不卡视频在线观看| 国产精品一站二站| 9国产精品视频| 女生影院久久| 国产精品视频一区二区三区 | 美女精品在线观看| 久久精品影视| 美女一区网站| 成人在线免费观看网站| 日韩国产在线一| 少妇精品久久久一区二区| 亚洲一区二区毛片| 亚洲午夜av| 亚洲成av人片一区二区密柚| 中文字幕在线官网| 91视频一区| 毛片在线网站| 成人精品中文字幕| 人人精品亚洲| 今天的高清视频免费播放成人| 欧洲精品一区二区三区| 国产v综合v| 国产综合欧美| 波多野结衣一区| 亚洲美洲欧洲综合国产一区| 黄色精品网站| 亚洲综合日本| 视频一区二区欧美| 蜜臀久久久久久久| 亚洲欧美在线综合| 亚洲欧美网站在线观看| 亚洲精品九九| 欧美亚洲专区| 久久影院一区二区三区| 久久一区精品| jizzjizz中国精品麻豆| 亚洲黄色网址| 亚洲手机在线| 鲁大师成人一区二区三区| 亚洲精品成a人ⅴ香蕉片| 日本强好片久久久久久aaa| 国产一精品一av一免费爽爽| 国产乱码精品一区二区三区四区 | 不卡在线一区| 蜜臀国产一区二区三区在线播放| 亚洲精选成人| 国产伦理久久久久久妇女| 精品视频一区二区三区四区五区| 国产一区国产二区国产三区| www.51av欧美视频| 亚洲成av人片一区二区密柚 | 爽好多水快深点欧美视频| 亚洲日本三级| 国产精品国码视频| 在线天堂中文资源最新版| 久久九九国产| 亚洲香蕉久久| 国产精品久久久久毛片大屁完整版| 欧美激情视频一区二区三区免费| 国产不卡精品在线| 红桃视频欧美| 欧美日本久久| 福利片在线一区二区| 少妇久久久久| 亚洲欧美日韩视频二区| 欧美亚洲综合视频| yellow在线观看网址| 婷婷亚洲五月| 亚洲91在线| 精品精品国产三级a∨在线| 亚洲午夜一级| 欧美自拍一区| 亚洲免费福利| 亚洲免费毛片| 欧美日韩在线观看首页| 99成人在线| 日韩va亚洲va欧美va久久| 国产一区一一区高清不卡| 欧美99久久| 欧美私人啪啪vps| 国产aⅴ精品一区二区三区久久| 日韩精品免费一区二区在线观看| 另类亚洲自拍| 水蜜桃精品av一区二区| 六月天综合网| 精品久久福利| 只有精品亚洲| 98精品视频| 日本成人在线视频网站| 国产亚洲电影| 久久精品高清| 麻豆国产精品视频| 91午夜精品| 国产极品嫩模在线观看91精品| 国内揄拍国内精品久久| 欧美va天堂在线| 91精品国产自产观看在线| 福利一区和二区| 亚洲中字黄色| 青草国产精品| 女生影院久久| 婷婷综合成人| 成人污污视频| 免费日韩视频| 国产精品欧美在线观看| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 精品国产乱码久久久| 久久国产影院| 日本久久一区| 精品捆绑调教一区二区三区| 视频一区二区三区入口| 精品午夜久久| 黄色国产精品| 捆绑调教美女网站视频一区| 国产国产精品| 美女毛片一区二区三区四区最新中文字幕亚洲| 久久精品国产68国产精品亚洲| 日韩精品免费视频人成| 电影亚洲精品噜噜在线观看| 日韩精品视频网| 欧美午夜精品一区二区三区电影| 91精品国产自产在线丝袜啪| 成人片免费看| 91久久精品无嫩草影院| 久久精品电影| 97精品视频在线看| 你懂的国产精品| 日本不卡视频一二三区| 亚洲欧美视频一区二区三区|