假设现在有三台主机,两台主库分别为master1,master2,一台从库slave
1,在主库上分别开启二进制日志,并且配置不同server-id;
[mysqld]
log-bin=mysql-bin
server-id=1
2,分别在两台主库创建一个专用于复制的用户,并且赋予复制权限;
CREATE USER 'repl'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
3,分别在两个主库执行状态查询,并且记录查询状态;
SHOW MASTER STATUS;
分别记录file,position,假设master1查询结果为file1,pos1,master2查存结果为file2,pos2
4,配置从库
1),设置如下两个变量值为table;
set global master_info_repository='TABLE';
set global relay_log_info_repository='TABLE';
2),分别执行如下设置语句:
CHANGE MASTER TO
MASTER_HOST='master1,
MASTER_USER='repl',
MASTER_PASSWORD='password',
MASTER_LOG_FILE='file1',
MASTER_LOG_POS=rpos1 for channel 'master1';
CHANGE MASTER TO
MASTER_HOST='master2,
MASTER_USER='repl',
MASTER_PASSWORD='password',
MASTER_LOG_FILE='file2',
MASTER_LOG_POS=rpos2 for channel 'master2';
3),启动从库复制
同时启动:
start slave;
也可以分别启动:
start slave for channel 'master1';
start slave for channel 'master2';
同时停止:
stop slave;
也可以分别停止:
stop slave for channel 'master1';
stop slave for channel 'master2';
注意:如果通过虚拟机来操作的过程中,有拷贝虚拟机的情况,比如通过拷贝master1来创建虚slave,
那么很可能会出现从库不能启动问题,此时需要在从库执行以下操作:
1,清空从库以下表格:
slave_master_info
slave_relay_log_info
slave_worker_info
innodb_index_stats
innodb_table_stats
2,停止mysqld服务,删除数据目录下的auto.cnf文件,重新启动mysqld服务;
3,继续配置从库。