亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL5.6基于GTID的主從復制

2024-07-24 13:08:49
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了MySQL5.6基于GTID的主從復制的相關資料,需要的朋友可以參考下
 

MySQL 5.6 的新特性之一,是加入了全局事務 ID (GTID) 來強化數據庫的主備一致性,故障恢復,以及容錯能力。

什么是GTID?

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

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

一、環境準備

操作系統:CentOS6.5 64位

數據庫版本:MySQL5.6.23

MySQL5.6基于GTID的主從復制

拓撲如下:

MySQL5.6基于GTID的主從復制

三、安裝主數據庫(masterdb.example.com)

1、準備數據存放目錄、創建用戶

[root@masterdb ~]#mkdir /data/mysqldata -p #創建數據存放目錄[root@masterdb ~]#mkdir /data/mysqlLog/logs -p #創建日志存放目錄[root@masterdb ~]#groupadd -r mysql[root@masterdb ~]#useradd -g mysql -r -s /sbin/nologin -M -d /data/mysqldata mysql[root@masterdb ~]#chown -R mysql:mysql /data/mysqldata[root@masterdb ~]#chown -R mysql:mysql /data/mysqlLog/logs

 2、安裝并初始化mysql5.6.23

[root@masterdb ~]# tar xf mysql-advanced-5.6.23-linux-glibc2.5-x86_64.tar.gz -C /usr/local/[root@masterdb ~]# cd /usr/local/[root@masterdb ~]# ln -sv mysql-advanced-5.6.23-linux-glibc2.5-x86_64 mysql[root@masterdb ~]# chown -R root.mysql mysql[root@masterdb ~]# cd mysql[root@masterdb ~]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld[root@masterdb ~]# cp support-files/my-default.cnf /etc/my.cnf[root@masterdb ~]# chmod +x /etc/rc.d/init.d/mysqld[root@masterdb ~]# chkconfig --add mysqld[root@masterdb ~]# chkconfig mysqld on[root@masterdb ~]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysqldata/ 

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

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

4、輸出mysql的頭文件至系統頭文件路徑/usr/include:

這可以通過簡單的創建鏈接實現:

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

5、輸出mysql的庫文件給系統庫查找路徑:

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

而后讓系統重新載入系統庫:

[root@masterdb ~]# ldconfig

6、修改PATH環境變量,讓系統可以直接使用mysql的相關命令:

[root@masterdb ~]# vim /etc/profile.d/mysql.shexport PATH=$PATH:/usr/local/mysql/bin[root@masterdb ~]#source /etc/profile.d/mysql.sh

從數據庫安裝同上,具體過程略過。

四、分別為主從數據庫提供配置文件/etc/my.cnf

要在MySQL 5.6中使用復制功能,其服務配置段[mysqld]中于少應該定義如下選項:
binlog-format:二進制日志的格式,有row、statement和mixed幾種類型;
需要注意的是:當設置隔離級別為READ-COMMITED必須設置二進制日志格式為ROW,現在MySQL官方認為STATEMENT這個已經不再適合繼續使用;但mixed類型在默認的事務隔離級別下,可能會導致主從數據不一致;
log-slave-updates、gtid-mode、enforce-gtid-consistency、report-port和report-host:用于啟動GTID及滿足附屬的其它需求;
master-info-repository和relay-log-info-repository:啟用此兩項,可用于實現在崩潰時保證二進制及從服務器安全的功能;
sync-master-info:啟用之可確保無信息丟失;
slave-paralles-workers:設定從服務器的SQL線程數;0表示關閉多線程復制功能;
binlog-checksum、master-verify-checksum和slave-sql-verify-checksum:啟用復制有關的所有校驗功能;
binlog-rows-query-log-events:啟用之可用于在二進制日志記錄事件相關的信息,可降低故障排除的復雜度;
log-bin:啟用二進制日志,這是保證復制功能的基本前提;
server-id:同一個復制拓撲中的所有服務器的id號必須惟一;

主數據庫上:

[client]port = 3306socket = /tmp/mysql.sockdefault-character-set = utf8[mysql]no-auto-rehashdefault-character-set = utf8[mysqld]server-id = 1port = 3306user = mysqlbasedir = /usr/local/mysqldatadir = /data/mysqldatasocket = /tmp/mysql.sockdefault-storage-engine = INNODBcharacter-set-server = utf8connect_timeout = 60interactive_timeout = 28800wait_timeout = 28800back_log = 500event_scheduler = ONskip_name_resolve = ON;###########binlog##########log-bin = /data/mysqlLog/logs/mysql-binbinlog_format = rowmax_binlog_size = 128Mbinlog_cache_size = 2Mexpire-logs-days = 5log-slave-updates=truegtid-mode=onenforce-gtid-consistency=truemaster-info-repository=TABLErelay-log-info-repository=TABLEsync-master-info=1slave-parallel-workers=4#rpl_semi_sync_master_enabled = 1slow_query_log = 1slow_query_log_file = /data/mysqlLog/logs/mysql.slowlong_query_time = 1log_error = /data/mysqlLog/logs/error.logmax_connections = 3000max_connect_errors = 32767log_bin_trust_function_creators = 1transaction_isolation = READ-COMMITTED

從數據庫上:

[client]port = 3306socket = /tmp/mysql.sockdefault-character-set = utf8[mysql]no-auto-rehashdefault-character-set = utf8[mysqld]server-id = 205port = 3306user = mysqlbasedir = /usr/local/mysqldatadir = /data/mysqldatasocket = /tmp/mysql.sockdefault-storage-engine = INNODBcharacter-set-server = utf8connect_timeout = 60wait_timeout = 18000back_log = 500event_scheduler = ON###########binlog##########log-bin = /data/mysqlLog/logs/mysql-binbinlog_format = rowmax_binlog_size = 128Mbinlog_cache_size = 2Mexpire-logs-days = 5log-slave-updates=truegtid-mode=on enforce-gtid-consistency=truemaster-info-repository=TABLErelay-log-info-repository=TABLEsync-master-info=1slave-parallel-workers=4#rpl_semi_sync_slave_enabled = 1skip-slave-startslow_query_log = 1slow_query_log_file = /data/mysqlLog/logs/mysql.slowlong_query_time = 2log-error = /data/mysqlLog/logs/error.logmax_connections = 3000max_connect_errors = 10000log_bin_trust_function_creators = 1transaction_isolation = READ-COMMITTED

五、分別在主從數據庫上啟動mysqld服務

[root@masterdb ~]# service mysqld startStarting MySQL......          [ OK ][root@masterdb ~]# [root@slavedb ~]# service mysqld startStarting MySQL......          [ OK ][root@slavedb ~]# 

六、在主數據庫上創建復制用戶

復制代碼代碼如下:
mysql> GRANT REPLICATION SLAVE ON *.* TO repluser@172.16.88.205 IDENTIFIED BY 'replpassword';

說明:172.16.88.205是從節點服務器;如果想一次性授權更多的節點,可以自行根據需要修改;

 

七、啟動從數據庫上的復制線程

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

八、在從數據庫上查看復制狀態

mysql> show slave status/G;*************************** 1. row ***************************    Slave_IO_State: Waiting for master to send event     Master_Host: masterdb.56xyl.com     Master_User: repluser     Master_Port: 3306    Connect_Retry: 60    Master_Log_File: mysql-bin.000002   Read_Master_Log_Pos: 191    Relay_Log_File: slavedb-relay-bin.000003    Relay_Log_Pos: 401  Relay_Master_Log_File: mysql-bin.000002    Slave_IO_Running: Yes #IO線程已正常運行   Slave_SQL_Running: Yes #SQL線程已正常運行    Replicate_Do_DB:    Replicate_Ignore_DB:    Replicate_Do_Table:   Replicate_Ignore_Table:   Replicate_Wild_Do_Table:  Replicate_Wild_Ignore_Table:      Last_Errno: 0     Last_Error:      Skip_Counter: 0   Exec_Master_Log_Pos: 191    Relay_Log_Space: 1899    Until_Condition: None    Until_Log_File:     Until_Log_Pos: 0   Master_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: 0    Last_IO_Error:     Last_SQL_Errno: 0    Last_SQL_Error:  Replicate_Ignore_Server_Ids:     Master_Server_Id: 1     Master_UUID: 971d7245-c3f8-11e5-8b6b-000c2999e5a5    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 the slave I/O thread to update it   Master_Retry_Count: 86400     Master_Bind:   Last_IO_Error_Timestamp:   Last_SQL_Error_Timestamp:     Master_SSL_Crl:    Master_SSL_Crlpath:    Retrieved_Gtid_Set: 971d7245-c3f8-11e5-8b6b-000c2999e5a5:1-6   Executed_Gtid_Set: 89e78301-c3f4-11e5-8b51-00505624d26a:1-3,971d7245-c3f8-11e5-8b6b-000c2999e5a5:1-6    Auto_Position: 11 row in set (0.00 sec)ERROR: No query specifiedmysql> 


九、測試

在主庫上創建數據庫:

mysql> create database log_statics;Query OK, 1 row affected (0.11 sec) mysql> use log_statics;Database changed到從數據庫上查看log_statics是否已經復制過去mysql> show databases;+--------------------+| Database   |+--------------------+| information_schema || log_statics  || mysql    || performance_schema |+--------------------+4 rows in set (0.01 sec)mysql>

可以看到log_statics數據庫已經存在于從數據庫上。

以上就是本文的全部內容,希望對大家的學習有所幫助。



注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人精品久久二区二区| 亚洲第一在线视频| 国产美女搞久久| 欧美午夜片欧美片在线观看| 欧美一级免费视频| 最近2019年手机中文字幕| 国产精品视频导航| 成人精品一区二区三区电影免费| 欧美劲爆第一页| 亚洲色图美腿丝袜| 2019中文在线观看| 久久久综合免费视频| 精品国产福利视频| 日韩精品极品视频免费观看| 国产视频精品va久久久久久| 亚洲国产成人久久综合一区| 清纯唯美亚洲综合| 亚洲国产高潮在线观看| 91视频国产精品| 久久国产精品网站| 国外色69视频在线观看| 欧美高清视频一区二区| 亚洲有声小说3d| 国产日韩欧美黄色| 性色av一区二区咪爱| 日韩电影中文字幕一区| 国产免费观看久久黄| 国产欧美精品一区二区三区介绍| 国产精品白嫩美女在线观看| 亚洲综合在线播放| 欧美极品少妇xxxxⅹ免费视频| 国产91网红主播在线观看| 亚洲欧美精品一区二区| 一区二区三区无码高清视频| 国产精品高清网站| 欧美大片va欧美在线播放| 久久综合免费视频影院| 日韩欧美a级成人黄色| 国产欧美最新羞羞视频在线观看| 精品无人国产偷自产在线| 成人性生交大片免费看视频直播| 成人免费网站在线看| 97精品国产97久久久久久免费| 国产日韩亚洲欧美| 欧美在线免费观看| 91tv亚洲精品香蕉国产一区7ujn| 日本免费一区二区三区视频观看| 亚洲精品视频免费| 亚洲情综合五月天| 欧美国产日韩在线| 中文字幕欧美日韩va免费视频| 91社影院在线观看| 日韩一区在线视频| 45www国产精品网站| 亚洲女人被黑人巨大进入al| 最近2019中文字幕第三页视频| 亚洲精品短视频| 欧美影院成年免费版| 久久婷婷国产麻豆91天堂| 国产一区二区三区免费视频| 国产一区二区三区高清在线观看| 午夜免费久久久久| 欧美乱大交做爰xxxⅹ性3| 亚洲激情在线观看视频免费| 午夜精品视频网站| 91在线看www| 精品国产一区二区三区久久久狼| 国产欧美 在线欧美| 日韩av片电影专区| 国产欧美精品xxxx另类| 狠狠色狠狠色综合日日小说| 三级精品视频久久久久| 欧美日韩在线视频一区二区| 国产91精品网站| 91在线无精精品一区二区| 亚洲香蕉成人av网站在线观看| 欧美视频国产精品| 国产一区二区三区在线观看视频| 青草热久免费精品视频| 欧美特黄级在线| 久久欧美在线电影| 亚洲一区二区三区成人在线视频精品| 亚洲国产天堂久久综合| 国产日韩在线观看av| 亚洲美女性生活视频| 国产一区二区在线播放| 色视频www在线播放国产成人| 成人在线播放av| 96pao国产成视频永久免费| 青青在线视频一区二区三区| 爱福利视频一区| 久久噜噜噜精品国产亚洲综合| 亚洲色图综合久久| 中文字幕日韩综合av| 97免费视频在线| 欧美日韩在线观看视频小说| 久久久久久国产免费| 欧美性猛交xxxx免费看久久久| 国产一区视频在线播放| 成人欧美一区二区三区在线湿哒哒| 国产91露脸中文字幕在线| 亚洲精品福利资源站| 91av在线影院| 欧美日韩电影在线观看| 国产精选久久久久久| 国产精品在线看| 亚洲欧美国产精品va在线观看| 久久久久久久久久久久久久久久久久av| 日本精品中文字幕| 97热在线精品视频在线观看| 久久久女女女女999久久| 久久久久女教师免费一区| 亚洲福利影片在线| 国产aⅴ夜夜欢一区二区三区| 在线播放亚洲激情| 一区二区三区国产在线观看| 91九色国产视频| 国产精品在线看| 97国产在线观看| 久久天天躁狠狠躁夜夜躁| 91老司机在线| 国产精品最新在线观看| 国产精品激情av电影在线观看| 亚洲国产成人在线播放| 搡老女人一区二区三区视频tv| 777国产偷窥盗摄精品视频| 国产婷婷97碰碰久久人人蜜臀| 亚洲综合中文字幕在线| 色播久久人人爽人人爽人人片视av| 97超级碰碰人国产在线观看| 欧美色视频日本高清在线观看| 亚洲美腿欧美激情另类| 国产91九色视频| 影音先锋欧美精品| 97视频com| 亚洲视频电影图片偷拍一区| 亚洲伊人久久综合| 久久精品国产精品亚洲| 欧美一级视频免费在线观看| 色樱桃影院亚洲精品影院| 91香蕉国产在线观看| 欧美高清视频在线| 亚洲国产欧美在线成人app| 91国产精品电影| 亚洲片在线观看| 久久久免费精品视频| 国产欧美一区二区三区四区| 伊人精品在线观看| 亚洲第一精品自拍| 国产精品视频色| 91在线无精精品一区二区| 国产精品福利无圣光在线一区| 亚洲japanese制服美女| 精品久久久视频| 久久99久久99精品中文字幕| 91在线免费视频| 国产视频精品自拍| 欧美日韩999| 日韩在线观看电影| 久久精品一区中文字幕| 国产精品成人aaaaa网站| 日韩福利伦理影院免费| 国产成人精品久久亚洲高清不卡| 中文综合在线观看|