欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL5.6基于GTID的主從復(fù)制

 更新時(shí)間:2016年02月19日 14:45:21   投稿:lijiao  
這篇文章主要介紹了MySQL5.6基于GTID的主從復(fù)制的相關(guā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ù)淙缦拢?/p>

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

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

[root@masterdb ~]#mkdir /data/mysqldata -p #創(chuàng)建數(shù)據(jù)存放目錄
[root@masterdb ~]#mkdir /data/mysqlLog/logs -p #創(chuàng)建日志存放目錄
[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手冊(cè)至man命令的查找路徑:

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

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

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

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

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

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

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

[root@masterdb ~]# ldconfig

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

[root@masterdb ~]# vim /etc/profile.d/mysql.sh
export PATH=$PATH:/usr/local/mysql/bin
[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幾種類型;
需要注意的是:當(dāng)設(shè)置隔離級(jí)別為READ-COMMITED必須設(shè)置二進(jìn)制日志格式為ROW,現(xiàn)在MySQL官方認(rèn)為STATEMENT這個(gè)已經(jīng)不再適合繼續(xù)使用;但mixed類型在默認(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:?jiǎn)⒂么藘身?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:?jiǎn)⒂脧?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ù)上:

[client]
port = 3306
socket = /tmp/mysql.sock
default-character-set = utf8
[mysql]
no-auto-rehash
default-character-set = utf8

[mysqld]
server-id = 1
port = 3306
user = mysql
basedir = /usr/local/mysql
datadir = /data/mysqldata
socket = /tmp/mysql.sock
default-storage-engine = INNODB
character-set-server = utf8
connect_timeout = 60
interactive_timeout = 28800
wait_timeout = 28800
back_log = 500
event_scheduler = ON
skip_name_resolve = ON;

###########binlog##########
log-bin = /data/mysqlLog/logs/mysql-bin
binlog_format = row
max_binlog_size = 128M
binlog_cache_size = 2M
expire-logs-days = 5
log-slave-updates=true
gtid-mode=on
enforce-gtid-consistency=true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info=1
slave-parallel-workers=4
#rpl_semi_sync_master_enabled = 1

slow_query_log = 1
slow_query_log_file = /data/mysqlLog/logs/mysql.slow
long_query_time = 1

log_error = /data/mysqlLog/logs/error.log
max_connections = 3000
max_connect_errors = 32767
log_bin_trust_function_creators = 1
transaction_isolation = READ-COMMITTED

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

[client]
port = 3306
socket = /tmp/mysql.sock
default-character-set = utf8

[mysql]
no-auto-rehash
default-character-set = utf8

[mysqld]
server-id = 205
port = 3306
user = mysql
basedir = /usr/local/mysql
datadir = /data/mysqldata
socket = /tmp/mysql.sock
default-storage-engine = INNODB
character-set-server = utf8
connect_timeout = 60
wait_timeout = 18000
back_log = 500
event_scheduler = ON

###########binlog##########
log-bin = /data/mysqlLog/logs/mysql-bin
binlog_format = row
max_binlog_size = 128M
binlog_cache_size = 2M
expire-logs-days = 5
log-slave-updates=true
gtid-mode=on 
enforce-gtid-consistency=true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info=1
slave-parallel-workers=4
#rpl_semi_sync_slave_enabled = 1
skip-slave-start

slow_query_log = 1
slow_query_log_file = /data/mysqlLog/logs/mysql.slow
long_query_time = 2

log-error = /data/mysqlLog/logs/error.log
max_connections = 3000
max_connect_errors = 10000
log_bin_trust_function_creators = 1
transaction_isolation = READ-COMMITTED

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

[root@masterdb ~]# service mysqld start
Starting MySQL......     [ OK ]
[root@masterdb ~]# 


[root@slavedb ~]# service mysqld start
Starting MySQL......     [ OK ]
[root@slavedb ~]# 

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

復(fù)制代碼 代碼如下:
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: 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線程已正常運(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: 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: 0
Master_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: 1
1 row in set (0.00 sec)

ERROR: 
No query specified

mysql> 


九、測(cè)試

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

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

mysql>

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

最新評(píng)論