MYSQL架構(gòu)中該怎么主從GTID

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)MySQL架構(gòu)中該怎么主從GTID,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

創(chuàng)新互聯(lián)是一家業(yè)務(wù)范圍包括IDC托管業(yè)務(wù),網(wǎng)站空間、主機(jī)租用、主機(jī)托管,四川、重慶、廣東電信服務(wù)器租用,服務(wù)器主機(jī)托管,成都網(wǎng)通服務(wù)器托管,成都服務(wù)器租用,業(yè)務(wù)范圍遍及中國(guó)大陸、港澳臺(tái)以及歐美等多個(gè)國(guó)家及地區(qū)的互聯(lián)網(wǎng)數(shù)據(jù)服務(wù)公司。

GTID又叫全局事務(wù)ID(Global Transaction ID),是一個(gè)已提交事務(wù)的編號(hào),并且是一個(gè)全局唯一的編號(hào),Mysql 5.6版本之后在主從復(fù)制類型上新增了GTID復(fù)制。

GTID是由server_uuid和事務(wù)ID組成的。即GUID=server_id:transaction_id.server_uuid是在數(shù)據(jù)庫(kù)啟動(dòng)過程中自動(dòng)生成的。每臺(tái)機(jī)器的server_uuid不一樣,同一環(huán)境刪除重新搭建之后也不一樣。

工作原理:

1.      master更新數(shù)據(jù)時(shí),會(huì)在事務(wù)前產(chǎn)生GTID,一同記錄到binlog日志中。

2.      slave端的I/O線程將變更的binlog,寫入到本地的relay log中。

3.      sql線程從relay log中獲取GTID,然后對(duì)比slave端的binlog是否有記錄。

4.      如果有記錄,說明該GTID的事務(wù)已經(jīng)執(zhí)行,slave會(huì)忽略。

5.      如果沒有記錄,slave就會(huì)從relay log中執(zhí)行該GTID的事務(wù),并記錄到binlog.

環(huán)境配置

/

服務(wù)器

從服務(wù)器

Ip

192.168.31.79

192.168.31.188

hostname

mysql

mysql2

mysql-version

5.7.23

5.7.23

Server-id

f99accbf-6690-11ea-a934-080027c1c1ff

a535303f-668e-11ea-8be9-080027b0e953

1.主庫(kù)配置

1.1參數(shù)配置

[root@mysql2 bin]# vi /etc/my.cnf

添加內(nèi)容如下

gtid_mode=on

enforce_gtid_consistency=on

log_bin=on

binlog_format=row

server-id=79

[root@mysql2 bin]# service mysql stop

[root@mysql2 bin]# service mysql stop

1.2權(quán)限配置

[root@mysql bin]# mysql -uroot -p

mysql> grant replication slave on *.* to 'rep'@'192.168.31.%' identified by 'Oracle123';

mysql> flush privileges;

2.主庫(kù)備份數(shù)據(jù)至從庫(kù)恢復(fù)

注:如果是新搭建的環(huán)境,可以不用做遷移步驟。

3.從庫(kù)配置

2.1 從庫(kù)參數(shù)配置

[root@mysql2 bin]# vi /etc/my.cnf

添加內(nèi)容如下

gtid_mode=on

enforce_gtid_consistency=on

log_slave_updates=1

serve-id=188

2.2從庫(kù)權(quán)限配置

[root@mysql2 bin]# mysql -uroot -p

mysql> change master to master_host='192.168.31.79', master_user='rep',master_password='Oracle123',master_port=3306,master_auto_position=1;

mysql> start slave;

3.檢查主從狀態(tài)

1)主庫(kù)

mysql> show master status;

 MYSQL架構(gòu)中該怎么主從GTID

2)從庫(kù)

mysql> show slave status\G;

 MYSQL架構(gòu)中該怎么主從GTID

MYSQL架構(gòu)中該怎么主從GTID

4.驗(yàn)證

1)主庫(kù)

mysql> create database test;

2)從庫(kù)

mysql> show databases;

MYSQL架構(gòu)中該怎么主從GTID

注:

在mysql 5.7版本之后,gtid_executed數(shù)值會(huì)被持久化

mysql> use mysql

mysql> desc gtid_executed;

mysql> select * from gtid_executed;

MYSQL架構(gòu)中該怎么主從GTID

在執(zhí)行reset master中,會(huì)清空表內(nèi)的數(shù)據(jù)。

 mysql> show variables like '%gtid_executed%';

該參數(shù)用來控制gtid_executed表的壓縮。默認(rèn)值是1000.意味著表壓縮在執(zhí)行1000個(gè)

事務(wù)之后開始。

上述就是小編為大家分享的MYSQL架構(gòu)中該怎么主從GTID了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

文章題目:MYSQL架構(gòu)中該怎么主從GTID
文章鏈接:http://bm7419.com/article48/jdsoep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈商城網(wǎng)站、動(dòng)態(tài)網(wǎng)站、網(wǎng)站建設(shè)、定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

營(yíng)銷型網(wǎng)站建設(shè)