本文主要給大家介紹MySQL在做主從復(fù)制時(shí)如何使用GTID,希望可以給大家補(bǔ)充和更新些知識,如有其它問題需要了解的可以持續(xù)在創(chuàng)新互聯(lián)行業(yè)資訊里面關(guān)注我的更新文章的。
成都創(chuàng)新互聯(lián)從2013年成立,先為山亭等服務(wù)建站,山亭等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為山亭企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
MySQL在5.6后多了一個(gè)新的功能就是在做主從復(fù)制時(shí)使用GTID,和傳統(tǒng)的使用relaylog中指定log_pos+log_file的主從復(fù)制相比,在使用GTID做主從復(fù)制時(shí)可以不指定slave需求讀取master中的哪一個(gè)binlog和偏移量。在傳統(tǒng)的MySQL主從復(fù)制中,一旦指定錯(cuò)誤master的偏移量后,那么就會造成主從不一致,而在基于GTID做的主從復(fù)制中就不會發(fā)生這樣的問題。GTID實(shí)際上是master提交了一次事務(wù)后而產(chǎn)生的ID,所以在配置的過程中一般都會開啟enforce_gtid_consistency(強(qiáng)制事務(wù)一致)的配置參數(shù)以確保GTID的安全,但是需要注意的是如果開啟了開啟enforce_gtid_consistency,那么在在事務(wù)中就不能創(chuàng)建和刪除臨時(shí)表,這一點(diǎn)需要注意,如創(chuàng)建臨時(shí)表:
create temporary table 建議改成 create table
除此外還會開啟log_slave_updates,這個(gè)變量在master和slave中都會開啟,除此之外毋庸置疑的是一定需要開啟binlog,至于其它大體和log_pos+log_file的主從復(fù)制類似,在此就說以一下不一樣的地方,至于其它的以前有說過log_pos+log_file的主從復(fù)制需要的可以參看:http://jim123.blog.51cto.com/4763600/1862808,在master和slave中開啟GTID的相關(guān)變量,當(dāng)然如果是允許重啟的話先配置好二者my.cnf是更好的,其中二者的my.cnf的[mysqld]下都需要添加的是:
log_slave_updates = on gtid_mode = on enforce_gtid_consistency = on 在slave下建議開啟只讀: read_only = on relay_log_info_repository=TABLE #把主從的信息記錄在表中,缺省是和舊版本中一樣是寫在文件中 master_info_repository=TABLE #這一條寫在master上
其處,在配置的過程中最好把master的寫入關(guān)閉,開啟只讀:
mysql> set global read_only = ON; Query OK, 0 rows affected (0.00 sec)
在開啟相應(yīng)的變量參數(shù)后,在slave上做GTID的主從復(fù)制時(shí)使用master_auto_position會根據(jù)GTID找到log_pos+log_file,相比傳統(tǒng)的方式更為的方便
mysql> stop slave; Query OK, 0 rows affected (0.08 sec) mysql> change master to master_auto_position=0; Query OK, 0 rows affected (0.01 sec) mysql> change master to master_host='192.168.168.253',master_user='test_backup',master_password='test_backup',master_auto_position = 1; Query OK, 0 rows affected, 2 warnings (0.01 sec) mysql> start slave; Query OK, 0 rows affected (0.01 sec)
在開啟后可以查看GTID參數(shù)變量:
mysql> show global variables like '%GTID%';
當(dāng)然為了服務(wù)高可用,在使用GTID時(shí)MySQL也會開啟log_pos+log_file,只是我們就不需要想以前那樣手動指向log_pos+log_file,因此使用GTID的方式做主從復(fù)制修復(fù)時(shí)還和以前不一樣:
mysql> stop slave; Query OK, 0 rows affected (0.08 sec) mysql> change master to master_auto_position=0; Query OK, 0 rows affected (0.01 sec) mysql> change master to master_host='192.168.168.253',master_user='test_backup',master_password='test_backup',master_log_file='mysql-bin.000014',master_log_pos=405051906; Query OK, 0 rows affected, 2 warnings (0.01 sec) mysql> start slave; Query OK, 0 rows affected (0.01 sec)
當(dāng)然這個(gè)是基于GTID和binlog結(jié)合的恢復(fù)方式,在選擇主從復(fù)制的方式只要選擇其中一中恢復(fù)即可,如果只是業(yè)務(wù)不繁忙的情況下僅有少量的或沒有事務(wù)時(shí)也可以嘗試著使用跳過事務(wù)的方式來解決錯(cuò)誤:
mysql> STOP SLAVE; Query OK, 0 rows affected (0.01 sec) mysql> SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; Query OK, 0 rows affected (0.01 sec) mysql> START SLAVE; Query OK, 0 rows affected (0.01 sec)
此外需要注意的是在使用MySQL的GTID時(shí)是不支持GTID直接動態(tài)關(guān)閉,如果需要關(guān)閉則需要使用GTID的4種狀態(tài):
ON:開啟 OFF:關(guān)閉 OFF_PERMISSIVE:關(guān)閉準(zhǔn)備 ON_PERMISSIVE:開啟準(zhǔn)備
正常的開啟和關(guān)閉流程是:OFF <-> OFF_PERMISSIVE <-> ON_PERMISSIVE <-> ON,即
SET GLOBAL gtid_mode = 'OFF_PERMISSIVE'; SET GLOBAL gtid_mode = 'ON_PERMISSIVE'; SET GLOBAL enforce_gtid_consistency = ON;#在開啟準(zhǔn)備的過程中開啟 SET GLOBAL gtid_mode = 'ON';
最后,需要注意的是在開啟GTID復(fù)制時(shí)多個(gè)線程僅會使用一個(gè)事務(wù),實(shí)際如果開啟多線程復(fù)制時(shí)還是多線程復(fù)制,只是在查看線程列表時(shí)顯示的是只有一個(gè)。
看了以上關(guān)于MySQL在做主從復(fù)制時(shí)如何使用GTID,希望能給大家在實(shí)際運(yùn)用中帶來一定的幫助。本文由于篇幅有限,難免會有不足和需要補(bǔ)充的地方,如有需要更加專業(yè)的解答,可在官網(wǎng)聯(lián)系我們的24小時(shí)售前售后,隨時(shí)幫您解答問題的。