MySQL之——BinLog Replication升级为GTIDs Replication四步骤

来源:互联网 发布:申请售后淘宝客佣金 编辑:程序博客网 时间:2024/06/07 08:33

转载请注明出处:http://blog.csdn.net/l1028386804/article/details/52761122

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=onlog-binlog-slave-updatesenforce-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;

1 0