Rumah  >  Artikel  >  pangkalan data  >  MySQL之-四步实现BinLog Replication升级为GTIDs Replication的代码实例

MySQL之-四步实现BinLog Replication升级为GTIDs Replication的代码实例

黄舟
黄舟asal
2017-03-13 16:43:101160semak imbas

1、将Master和Slave服务器都设置为read-only

mysql>SET @@global.read_only=ON;

2、将Master与Slave服务器都停下来

service mysql stop

3、开启GTIDs

开启GTIDs需要在master和slave服务器上都配置gtid-mode,log-bin,log-slave-updates,enforce-gtid-consistency(在MySQL 5.6.9之前是--disable-gtid-unsafe-statement)。另外,slave在这个环节还需要增加skip-slave-start参数。

#vi /etc/my.cnf
[mysqld]
gtid-mode=on
log-bin
log-slave-updates
enforce-gtid-consistency

4、重新配置Slave

mysql> change master to
	-> master_host='xxx.xxx.xxx.xxx',
	-> master_port=3306,
	-> master_user='xxx',
	-> master_password='xxx',
	-> master_auto_position=1;
mysql > start slave;

至此,升级结束。下面我为大家新增一个GTIDs Replication的切换中继服务器或Master服务器的方法。

5、GTIDs Replication

GTIDs Replication可随意指定某一台服务器为另一台服务器的中继Slave服务器或者Master服务器。

比如A、B、C三台MySQL服务器,开始为A是B、C的Master服务器。目前要将B变成C的中继服务器。则具体操作方法如下:

1)在服务器B上执行如下命令
mysql>  GRANT REPLICATION SLAVE ON *.* TO 'lyz'@'C的ip地址' IDENTIFIED BY 'lyz';
2)在C服务器上依次执行以下操作

(1)停掉slave

mysql> stop slave;

(2)配置slave

mysql> change master to
	-> master_host='B的ip地址',
	-> master_port=3306,
	-> master_user='lyz',
	-> master_password='lyz',
	-> master_auto_position=1;

(3)启动slave

mysql > start slave;

Atas ialah kandungan terperinci MySQL之-四步实现BinLog Replication升级为GTIDs Replication的代码实例. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn