MySQL-5.6.14基於GTID及多線程的複製

實驗環境 RHEL-6.6-x86_64
mysql

兩臺主機 MASTER 192.168.1.5      hostname : master.mingxiao.infosql

SLAVE 192.168.1.6         hostname : slave.mingxiao.infobash


GTID簡介
服務器

GTID(Global Transaction Identifier)是每個事務提交時建立的一個全局惟一的標示符。socket

GTID由UUID:TID組成。ide

MySQL的UUID是怎麼得到的呢?當啓動MySQL時,嘗試讀取datadir/auto.cnf中的UUID,若沒找到,生成一個新的UUID,並保存至auto.cnf文件中。MySQL5.6版本,複製的時候,主從都直到對應的UUID,可經過SHOW SLAVE HOSTS看到。spa

TID(transaction_id)是已提交的事務數量,隨事務提交而遞增。
3d

GTID做用orm

  • 能夠定位事務是在哪一個實例上提交的server

  • 方便複製時故障轉移


wKioL1VUhCnhvALwAABAxMZK1GQ041.jpg

若Server A故障,須要將業務切換到Server B上。同時,咱們又須要將Server C的複製源改爲Server B,修改可以使用CHANGE MASTER TO MASTER_HOST='XXX', MASTER_USER='XXX', MASTER_USER='XXX',MASTER_PASSWORD='XXX',MASTER_LOG_FILE='XXX',MASTER_LOG_POS='XXX'便可.因爲同一個事務在每臺機器上所在的binlog名字和位置都不同,很難找到Server C當前同步中止點對應的MASTER_LOG_FILE和MASTER_LOG_POS是什麼。

可是出現GTID後,就變得很是簡單,因爲同一事務的GTID在全部節點都一致,則根據Server C的當前中止點的GTID就能惟必定位到Server B上的GTID。因爲MASTER_AUTO_POSITION功能的出現,咱們根本不須要GTID的具體值,直接使用CHANGE MASTER TO MASTER_HOST='XXX', MASTER_USER='XXX', MASTER_PASSWORD='XXX', MASTER_AUTO_POSITION=1;就能夠完成故障轉移的工做。

具體步驟

具體步驟

  一、同步時間

  二、兩臺主機分別初始化MySQL

  三、修改配置文件



master上my.cnf

[mysqld]
datadir=/mydata/data
socket = /tmp/mysql.sock
innodb-file-per-table = 1
server_id = 1
log-bin=master-bin
gtid-mode=on
binlog-format=ROW
log-slave-updates=true
enforce-gtid-consistency=true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info=1
slave-parallel-workers=2
binlog-checksum=CRC32
master-verify-checksum=1
slave-sql-verify-checksum=1
binlog-rows-query-log_events=1
report-port=3306
port=3306
report-host=master.mingxiao.info
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES



slave上my.cnf

[mysqld]
log-bin=master-bin
binlog-format=ROW
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=2
binlog-checksum=CRC32
master-verify-checksum=1
slave-sql-verify-checksum=1
binlog-rows-query-log_events=1
server-id=11
report-port=3306
port=3306
log-bin=mysql-bin.log
datadir=/mydata/data
socket=/tmp/mysql.sock
report-host=slave.mingxiao.info
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES



master上

mysql > GRANT REPLICATION SLAVE ON *.* TO 'repluser'@'192.168.1.6' IDENTIFIED BY 'xiaoming';
mysql > FLUSH PRIVILEGES;


slave上

mysql > GRANT MASTER TO MASTER_HOST='192.168.1.5', MASTER_USER='repluser',MASTER_PASSWORD='xiaoming',MASTER_AUTO_POSITION=1;
mysql > START SLAVE;


便可。


在master上查看從服務器信息。

mysql> SHOW SLAVE HOSTS;
+-----------+---------------------+------+-----------+--------------------------------------+
| Server_id | Host                | Port | Master_id | Slave_UUID                           |
+-----------+---------------------+------+-----------+--------------------------------------+
|        11 | slave.mingxiao.info | 3306 |         1 | 20459c95-f484-11e4-82a4-000c29c05a8a |
+-----------+---------------------+------+-----------+--------------------------------------+
1 row in set (0.00 sec)


在slave查看從服務器狀態

mysql> SHOW SLAVE STATUS\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.1.5
                  Master_User: repluser
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: master-bin.000004
          Read_Master_Log_Pos: 332
               Relay_Log_File: slave-relay-bin.000007
                Relay_Log_Pos: 451
        Relay_Master_Log_File: master-bin.000004
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              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: 332
              Relay_Log_Space: 955
              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: e168e12e-f5fc-11e4-8c3d-000c29b4e41b
             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: e168e12e-f5fc-11e4-8c3d-000c29b4e41b:1-5
            Executed_Gtid_Set: 
                Auto_Position: 1
1 row in set (0.00 sec)
相關文章
相關標籤/搜索