日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

mysql 5.6 gtid 主从_MySQL5.6基于GTID的主从复制

發(fā)布時(shí)間:2023/12/10 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 5.6 gtid 主从_MySQL5.6基于GTID的主从复制 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一、GTID簡(jiǎn)介

MySQL 5.6 的新特性之一,是加入了全局事務(wù) ID (GTID) 來(lái)強(qiáng)化數(shù)據(jù)庫(kù)的主備一致性,故障恢復(fù),以及容錯(cuò)能力。

什么是GTID?

官方文檔:http://dev.mysql.com/doc/refman/5.6/en/replication-gtids.html在這篇文檔里,我們可以知道全局事務(wù) ID 的官方定義是:GTID = source_id:transaction_id

MySQL 5.6 中,每一個(gè) GTID 代表一個(gè)數(shù)據(jù)庫(kù)事務(wù)。在上面的定義中,source_id 表示執(zhí)行事務(wù)的主庫(kù) uuid(server_uuid),transaction_id 是一個(gè)從 1 開(kāi)始的自增計(jì)數(shù),表示在這個(gè)主庫(kù)上執(zhí)行的第 n 個(gè)事務(wù)。MySQL 會(huì)保證事務(wù)與 GTID 之間的 1 : 1 映射。

二、環(huán)境準(zhǔn)備

操作系統(tǒng):CentOS6.5 64位

數(shù)據(jù)庫(kù)版本:MySQL5.6.23

拓?fù)淙缦?#xff1a;

三、安裝主數(shù)據(jù)庫(kù)(masterdb.example.com)

1、準(zhǔn)備數(shù)據(jù)存放目錄、創(chuàng)建用戶(hù)

1 1 [root@masterdb ~]#mkdir /data/mysqldata -p #創(chuàng)建數(shù)據(jù)存放目錄2 2 [root@masterdb ~]#mkdir /data/mysqlLog/logs -p #創(chuàng)建日志存放目錄3 3 [root@masterdb ~]#groupadd -r mysql4 4 [root@masterdb ~]#useradd -g mysql -r -s /sbin/nologin -M -d /data/mysqldata mysql5 5 [root@masterdb ~]#chown -R mysql:mysql /data/mysqldata6 6 [root@masterdb ~]#chown -R mysql:mysql /data/mysqlLog/logs

2、安裝并初始化mysql5.6.23

1 [root@masterdb ~]# tar xf mysql-advanced-5.6.23-linux-glibc2.5-x86_64.tar.gz -C /usr/local/

2 [root@masterdb ~]# cd /usr/local/

3 [root@masterdb ~]# ln -sv mysql-advanced-5.6.23-linux-glibc2.5-x86_64 mysql4 [root@masterdb ~]# chown -R root.mysql mysql5 [root@masterdb ~]# cd mysql6 [root@masterdb ~]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld7 [root@masterdb ~]# cp support-files/my-default.cnf /etc/my.cnf8 [root@masterdb ~]# chmod +x /etc/rc.d/init.d/mysqld9 [root@masterdb ~]# chkconfig --add mysqld10 [root@masterdb ~]# chkconfig mysqld on11 [root@masterdb ~]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysqldata/

3、輸出mysql的man手冊(cè)至man命令的查找路徑:

編輯/etc/man.config,添加如下行即可:

MANPATH? /usr/local/mysql/man

4、輸出mysql的頭文件至系統(tǒng)頭文件路徑/usr/include:

這可以通過(guò)簡(jiǎn)單的創(chuàng)建鏈接實(shí)現(xiàn):

1 [root@masterdb ~]#ln -sv /usr/local/mysql/include /usr/include/mysql

5、輸出mysql的庫(kù)文件給系統(tǒng)庫(kù)查找路徑:

1 [root@masterdb ~]#echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf

而后讓系統(tǒng)重新載入系統(tǒng)庫(kù):

1 [root@masterdb ~]# ldconfig

6、修改PATH環(huán)境變量,讓系統(tǒng)可以直接使用mysql的相關(guān)命令:

1 [root@masterdb ~]# vim /etc/profile.d/mysql.sh

2 export PATH=$PATH:/usr/local/mysql/bin3 [root@masterdb ~]#source /etc/profile.d/mysql.sh

從數(shù)據(jù)庫(kù)安裝同上,具體過(guò)程略過(guò)。

四、分別為主從數(shù)據(jù)庫(kù)提供配置文件/etc/my.cnf

要在MySQL 5.6中使用復(fù)制功能,其服務(wù)配置段[mysqld]中于少應(yīng)該定義如下選項(xiàng):

binlog-format:二進(jìn)制日志的格式,有row、statement和mixed幾種類(lèi)型;

需要注意的是:當(dāng)設(shè)置隔離級(jí)別為READ-COMMITED必須設(shè)置二進(jìn)制日志格式為ROW,現(xiàn)在MySQL官方認(rèn)為STATEMENT這個(gè)已經(jīng)不再適合繼續(xù)使用;但mixed類(lèi)型在默認(rèn)的事務(wù)隔離級(jí)別下,可能會(huì)導(dǎo)致主從數(shù)據(jù)不一致;

log-slave-updates、gtid-mode、enforce-gtid-consistency、report-port和report-host:用于啟動(dòng)GTID及滿足附屬的其它需求;

master-info-repository和relay-log-info-repository:啟用此兩項(xiàng),可用于實(shí)現(xiàn)在崩潰時(shí)保證二進(jìn)制及從服務(wù)器安全的功能;

sync-master-info:啟用之可確保無(wú)信息丟失;

slave-paralles-workers:設(shè)定從服務(wù)器的SQL線程數(shù);0表示關(guān)閉多線程復(fù)制功能;

binlog-checksum、master-verify-checksum和slave-sql-verify-checksum:啟用復(fù)制有關(guān)的所有校驗(yàn)功能;

binlog-rows-query-log-events:啟用之可用于在二進(jìn)制日志記錄事件相關(guān)的信息,可降低故障排除的復(fù)雜度;

log-bin:啟用二進(jìn)制日志,這是保證復(fù)制功能的基本前提;

server-id:同一個(gè)復(fù)制拓?fù)渲械乃蟹?wù)器的id號(hào)必須惟一;

主數(shù)據(jù)庫(kù)上:

1 [client]2 port = 3306

3 socket = /tmp/mysql.sock4 default-character-set =utf85 [mysql]6 no-auto-rehash7 default-character-set =utf88

9 [mysqld]10 server-id = 1

11 port = 3306

12 user =mysql13 basedir = /usr/local/mysql14 datadir = /data/mysqldata15 socket = /tmp/mysql.sock16 default-storage-engine =INNODB17 character-set-server =utf818 connect_timeout = 60

19 interactive_timeout = 28800

20 wait_timeout = 28800

21 back_log = 500

22 event_scheduler =ON23 skip_name_resolve =ON;24

25 ###########binlog##########26 log-bin = /data/mysqlLog/logs/mysql-bin27 binlog_format =row28 max_binlog_size =128M29 binlog_cache_size =2M30 expire-logs-days = 5

31 log-slave-updates=true

32 gtid-mode=on33 enforce-gtid-consistency=true

34 master-info-repository=TABLE35 relay-log-info-repository=TABLE36 sync-master-info=1

37 slave-parallel-workers=4

38 #rpl_semi_sync_master_enabled = 1

39

40 slow_query_log = 1

41 slow_query_log_file = /data/mysqlLog/logs/mysql.slow42 long_query_time = 1

43

44 log_error = /data/mysqlLog/logs/error.log45 max_connections = 3000

46 max_connect_errors = 32767

47 log_bin_trust_function_creators = 1

48 transaction_isolation = READ-COMMITTED

從數(shù)據(jù)庫(kù)上:

1 [client]2 port = 3306

3 socket = /tmp/mysql.sock4 default-character-set =utf85

6 [mysql]7 no-auto-rehash8 default-character-set =utf89

10 [mysqld]11 server-id = 205

12 port = 3306

13 user =mysql14 basedir = /usr/local/mysql15 datadir = /data/mysqldata16 socket = /tmp/mysql.sock17 default-storage-engine =INNODB18 character-set-server =utf819 connect_timeout = 60

20 wait_timeout = 18000

21 back_log = 500

22 event_scheduler =ON23

24 ###########binlog##########25 log-bin = /data/mysqlLog/logs/mysql-bin26 binlog_format =row27 max_binlog_size =128M28 binlog_cache_size =2M29 expire-logs-days = 5

30 log-slave-updates=true

31 gtid-mode=on32 enforce-gtid-consistency=true

33 master-info-repository=TABLE34 relay-log-info-repository=TABLE35 sync-master-info=1

36 slave-parallel-workers=4

37 #rpl_semi_sync_slave_enabled = 1

38 skip-slave-start39

40 slow_query_log = 1

41 slow_query_log_file = /data/mysqlLog/logs/mysql.slow42 long_query_time = 2

43

44 log-error = /data/mysqlLog/logs/error.log45 max_connections = 3000

46 max_connect_errors = 10000

47 log_bin_trust_function_creators = 1

48 transaction_isolation = READ-COMMITTED

五、分別在主從數(shù)據(jù)庫(kù)上啟動(dòng)mysqld服務(wù)

1 [root@masterdb ~]# service mysqld start2 Starting MySQL...... [ OK ]3 [root@masterdb ~]#

1 [root@slavedb ~]# service mysqld start2 Starting MySQL...... [ OK ]3 [root@slavedb ~]#

六、在主數(shù)據(jù)庫(kù)上創(chuàng)建復(fù)制用戶(hù)

1 mysql> GRANT REPLICATION SLAVE ON *.* TO repluser@172.16.88.205 IDENTIFIED BY 'replpassword';

說(shuō)明:172.16.88.205是從節(jié)點(diǎn)服務(wù)器;如果想一次性授權(quán)更多的節(jié)點(diǎn),可以自行根據(jù)需要修改;

七、啟動(dòng)從數(shù)據(jù)庫(kù)上的復(fù)制線程

mysql> CHANGE MASTER TO MASTER_HOST='masterdb.example.com', MASTER_USER='repluser', MASTER_PASSWORD='replpassword', MASTER_AUTO_POSITION=1;

mysql>start slave;

八、在從數(shù)據(jù)庫(kù)上查看復(fù)制狀態(tài):

mysql>show slave status\G;*************************** 1. row ***************************Slave_IO_State: Waitingformaster to send event

Master_Host: masterdb.56xyl.com

Master_User: repluser

Master_Port:3306Connect_Retry:60Master_Log_File: mysql-bin.000002Read_Master_Log_Pos:191Relay_Log_File: slavedb-relay-bin.000003Relay_Log_Pos:401Relay_Master_Log_File: mysql-bin.000002Slave_IO_Running: Yes #IO線程已正常運(yùn)行

Slave_SQL_Running: Yes #SQL線程已正常運(yùn)行

Replicate_Do_DB:

Replicate_Ignore_DB:

Replicate_Do_Table:

Replicate_Ignore_Table:

Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

Last_Errno:0Last_Error:

Skip_Counter:0Exec_Master_Log_Pos:191Relay_Log_Space:1899Until_Condition: None

Until_Log_File:

Until_Log_Pos:0Master_SSL_Allowed: No

Master_SSL_CA_File:

Master_SSL_CA_Path:

Master_SSL_Cert:

Master_SSL_Cipher:

Master_SSL_Key:

Seconds_Behind_Master:0Master_SSL_Verify_Server_Cert: No

Last_IO_Errno:0Last_IO_Error:

Last_SQL_Errno:0Last_SQL_Error:

Replicate_Ignore_Server_Ids:

Master_Server_Id:1Master_UUID: 971d7245-c3f8-11e5-8b6b-000c2999e5a5

Master_Info_File: mysql.slave_master_info

SQL_Delay:0SQL_Remaining_Delay: NULL

Slave_SQL_Running_State: Slave has read all relay log; waitingfor the slave I/O thread to update it

Master_Retry_Count:86400Master_Bind:

Last_IO_Error_Timestamp:

Last_SQL_Error_Timestamp:

Master_SSL_Crl:

Master_SSL_Crlpath:

Retrieved_Gtid_Set: 971d7245-c3f8-11e5-8b6b-000c2999e5a5:1-6Executed_Gtid_Set: 89e78301-c3f4-11e5-8b51-00505624d26a:1-3,

971d7245-c3f8-11e5-8b6b-000c2999e5a5:1-6Auto_Position:1

1 row in set (0.00sec)

ERROR:

No query specified

mysql>

九、測(cè)試

在主庫(kù)上創(chuàng)建數(shù)據(jù)庫(kù):

1 mysql>create database log_statics;2 Query OK, 1 row affected (0.11sec)3

4 mysql>use log_statics;5 Database changed

到從數(shù)據(jù)庫(kù)上查看log_statics是否已經(jīng)復(fù)制過(guò)去

1 mysql>show databases;2 +--------------------+

3 | Database |

4 +--------------------+

5 | information_schema |

6 | log_statics |

7 | mysql |

8 | performance_schema |

9 +--------------------+

10 4 rows in set (0.01sec)11

12 mysql>

可以看到log_statics數(shù)據(jù)庫(kù)已經(jīng)存在于從數(shù)據(jù)庫(kù)上。

--------------------------------------分割線 --------------------------------------

--------------------------------------分割線 --------------------------------------

總結(jié)

以上是生活随笔為你收集整理的mysql 5.6 gtid 主从_MySQL5.6基于GTID的主从复制的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。