MySQL互为主备配置详解:双向数据同步实战
首先梳理一下整体思路:两台MySQL服务器(本文称为A和B)需要实现数据的双向同步,即互为主备。虽然听起来复杂,但核心步骤只有三步:配置各自参数、建立复制通道、双向拉起同步。
前提条件是A和B两台机器网络互通。为了便于连接,建议先在hosts文件中将IP与主机名对应好,避免反复输入IP。hosts文件位于C:\Windows\System32\drivers\etc\hosts,添加如下内容:
192.168.124.88 node1 192.168.124.44 node2
其中node1代表数据库A的机器,node2代表数据库B的机器。下面开始具体配置。
数据库A的配置(在C:\ProgramData\MySQL\MySQL Server 8.0目录下的my.ini中添加):
server-id=1 log-bin=mysql-bin binlog_format=ROW gtid_mode=ON enforce_gtid_consistency=ON log_slave_updates=ON auto_increment_increment=2 auto_increment_offset=1
数据库B的配置(同样在my.ini中):
server-id=2 log-bin=mysql-bin binlog_format=ROW gtid_mode=ON enforce_gtid_consistency=ON log_slave_updates=ON auto_increment_increment=2 auto_increment_offset=2
配置保存后,重启MySQL服务。
重要提示:接下来的所有操作必须在一个“干净”的环境中进行。请确保数据已完成同步,然后——绝对不要再操作任何数据!任何写入、修改、删除操作都不允许。这是一个必须严格遵守的纪律。
千万注意:操作数据将导致前功尽弃!
数据库A的操作:
STOP REPLICA; RESET REPLICA ALL; RESET MASTER; -- 必须执行,执行后不得再进行任何数据库操作 CREATE USER 'repl'@'%' IDENTIFIED BY 'Repl@123456'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES; -- 针对MySQL 8.0以上版本的密码配置 ALTER USER 'repl'@'%' IDENTIFIED WITH mysql_native_password BY 'Repl@123456'; FLUSH PRIVILEGES;
数据库B的操作:
STOP REPLICA; RESET REPLICA ALL; RESET MASTER; -- 如果A上已经创建了用户,B这里理论上可以省略,但为了保险建议执行一遍 CREATE USER 'repl'@'%' IDENTIFIED BY 'Repl@123456'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES; ALTER USER 'repl'@'%' IDENTIFIED WITH mysql_native_password BY 'Repl@123456'; FLUSH PRIVILEGES;
前置条件准备完毕。请牢记:此时不能再对任何数据库数据执行操作。
先走A→B方向:将B配置为A的从库。
在B上执行:
CHANGE REPLICATION SOURCE TO SOURCE_HOST='node1', SOURCE_PORT=3306, SOURCE_USER='repl', SOURCE_PASSWORD='Repl@123456', SOURCE_AUTO_POSITION=1; START REPLICA;
验证A→B方向是否成功:
SHOW REPLICA STATUS;
重点关注以下三个字段:
Replica_IO_Running: Yes Replica_SQL_Running: Yes Seconds_Behind_Source: 0
若全部显示Yes且延迟为0,说明A→B这一方向的复制通道已打通。
建议确认A→B通后再进行下一步
再走B→A方向:将A配置为B的从库。
在A上执行:
CHANGE REPLICATION SOURCE TO SOURCE_HOST='node2', SOURCE_PORT=3306, SOURCE_USER='repl', SOURCE_PASSWORD='Repl@123456', SOURCE_AUTO_POSITION=1; START REPLICA;
同样验证B→A方向是否成功:
SHOW REPLICA STATUS;
仍然检查那三个关键字段:
Replica_IO_Running: Yes Replica_SQL_Running: Yes Seconds_Behind_Source: 0
如果全部正确,恭喜你,MySQL互为主备配置完成!此时A和B之间即可实现双向数据同步。
整个过程最核心的注意事项:配置过程中千万不要操作数据!任何数据修改都可能破坏GTID的一致性,导致同步失败。保持耐心,按步骤执行,成功率会非常高。
