配置MySQL GTID 主從複製

1、更簡單的實現failover,不用以前那樣在需要找log_file和log_pos。
2、更簡單的搭建主從複製。
3、比傳統的複製更加安全。
4、GTID是連續的沒有空洞的,保證數據的一致性,零丟失。

在slave端執行以下操作 (普通主從複製)——可參考https://blog.51cto.com/yangkui/2135027
(root@localhost) [(none)]> CHANGE MASTER TO
-> MASTER_HOST='192.168.1.135',
-> MASTER_USER='repl',
-> MASTER_PASSWORD='xxx',
-> MASTER_PORT=3306,
-> MASTER_AUTO_POSITION = 1;

Query OK, 0 rows affected, 2 warnings (0.01 sec)

(root@localhost) [(none)]> start slave;
Query OK, 0 rows affected (0.01 sec)

(root@localhost) [(none)]> show slave status \G ###可以看到複製工作已經開始且正常
1. row
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.1.135
Master_User: repl
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: master-binlog.000001
Read_Master_Log_Pos: 151
Relay_Log_File: slave-relay-log.000002
Relay_Log_Pos: 369
Relay_Master_Log_File: master-binlog.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

修改配置文件
1、主:

[mysqld]
#GTID:
server_id=135 #服務器id
gtid_mode=on #開啓gtid模式
enforce_gtid_consistency=on #強制gtid一致性,開啓後對於特定create table不被支持

#binlog
log_bin=master-binlog
log-slave-updates=1
binlog_format=row #強烈建議,其他格式可能造成數據不一致

#relay log
skip_slave_start=1

2、從:
[mysqld]
#GTID:
gtid_mode=on
enforce_gtid_consistency=on
server_id=143

#binlog
log-bin=slave-binlog
log-slave-updates=1
binlog_format=row #強烈建議,其他格式可能造成數據不一致

#relay log
skip_slave_start=1b、所有服務器設置global.read_only參數,等待主從服務器同步完畢;

mysql> SET @@global.read_only = ON;
c、依次重啓主從服務器;
d、使用change master 更新主從配置;
mysql> CHANGE MASTER TO

MASTER_HOST = host,
MASTER_PORT = port,
MASTER_USER = user,
MASTER_PASSWORD = password,
MASTER_AUTO_POSITION = 1;
e、從庫開啓複製
mysql> START SLAVE;
f、驗證主從複製

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章