
最近有个需要,国内和国外分别开了两台mysql数据库,要求是数据实时同步,不管那边访问,数据都是一样的。 其实好几年前,做过一次MySQL的主主同步,都已经忘记怎么做了。这次做完,顺便记录一下。
服务器A的IP:1.1.1.1 服务器B的IP:2.2.2.2
1、进入服务器A的shell,给服务器B授权,授权账号为tongbu,密码为123456
Mysql>GRANT all privileges ON *.* TO tongbu@'2.2.2.2' IDENTIFIED BY '123456';2、进入服务器B的shell,给服务器A授权,授权账号为tongbu,密码为123456
Mysql>GRANT all privileges ON *.* TO tongbu@'1.1.1.1' IDENTIFIED BY '123456';1、进入服务器A,编辑my.cnf文件:vi /etc/my.cnf
2、在[mysqld]的配置项中增加如下代码:
server-id=1
log-bin=mysql-bin
binlog-do-db=xxx_data
replicate-do-db=xxx_data
auto_increment_increment = 2
auto_increment_offset = 13、进入服务器B,编辑my.cnf文件:vi /etc/my.cnf
4、在[mysqld]的配置项中增加如下代码:
server-id=2
log-bin=mysql-bin
binlog-do-db=xxx_data
replicate-do-db=xxx_data
auto_increment_increment = 2
auto_increment_offset = 2xxx_data即你要同步的库,若有多个,就多写几行。auto_increment_offset设置自增起始值。auto_increment_increment主键自增的步长,用于防止Master与Master之间出现主键冲突(重复),通常有多少台主服务器,设置为多少服务器A、服务器B 分别执行mysql> show master status;得到File和Position。分别记录下来。

假设:
服务器A:File是mysql-bin.000009,Position是153
服务器B:File是mysql-bin.000010,Position是154
那么
服务器A执行:
Mysql> stop slave;CHANGE MASTER TO
MASTER_HOST='2.2.2.2',
MASTER_USER='tongbu',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000010',
MASTER_LOG_POS=154;Mysql> start slave;服务器B执行:
Mysql> stop slave;CHANGE MASTER TO
MASTER_HOST='1.1.1.1',
MASTER_USER='tongbu',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000009',
MASTER_LOG_POS=153;Mysql> start slave;重新启动MySQL:service mysqld restart
执行:Mysql> show slave status\G,如果其中显示两个Yes,即同步成功。可以测试数据同步效果。
......
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
......