17370845950

mysql主从复制如何切换主库_mysql主从切换流程
主库切换需确保从库同步完成:Seconds_Behind_Master=0且复制线程正常;原主库加读锁并记录binlog位点;目标从库停复制、重置配置、关闭read_only;其余从库重新CHANGE MASTER TO新主;最后解锁、验证同步与写入、更新路由。

确认从库已同步完成

切换前必须确保从库的复制已追上主库,否则会丢失数据。执行 SHOW SLAVE STATUS\G,重点检查以下两项:

  • Seconds_Behind_Master = 0:表示从库没有延迟
  • Slave_IO_Running 和 Slave_SQL_Running 都为 Yes:说明复制线程正常运行

若存在延迟,可等待同步完成,或在业务低峰期操作;必要时用 SELECT MASTER_POS_WAIT() 等待指定 binlog 位置。

停止原主库写入并刷新读写状态

为避免切主过程中产生新数据,需临时阻断原主库的写操作:

  • 在原主库执行 FLUSH TABLES WITH READ LOCK;(全局只读锁)
  • 再执行 SHOW MASTER STATUS; 记下当前 binlog 文件名和 position,后续从库需基于此点恢复
  • 保持连接不退出,防止锁自动释放

此时应用应停止向原主库写入,可配合服务层配置或代理(如 ProxySQL、HAProxy)将流量切至只读模式。

提升从库为新主库

在目标从库上执行以下步骤:

  • 停止复制:STOP SLAVE;
  • 重置复制信息(清除旧主配置):RESET SLAVE ALL;
  • 开启写能力(如有 read_only=ON,需关闭):SET GLOBAL read_only = OFF;
  • 确认无误后,该库即可作为新主库接受写请求

注意:若使用 GTID 复制,还需记录 SELECT @@GLOBAL.GTID_EXECUTED;,供后续其他从库重新指向新主时使用。

重新配置其他从库指向新主

原集群中其余从库需重新指向新的主库:

  • 在每个从库上先执行 STOP SLAVE;
  • 使用 CHANGE MASTER TO 指向新主库 IP、端口、账号密码,并指定正确的 binlog 文件与 position(或 GTID)
  • 启动复制:START SLAVE;,再用 SHOW SLAVE STATUS\G 验证

若原主库后续要转为从库,也按同样方式配置它指向新主库即可。

清理与验证

切换完成后需做几项收尾工作:

  • 在原主库执行 UNLOCK TABLES; 解除读锁
  • 检查新主库的写入是否正常(如插入测试数据、查 binlog 是否更新)
  • 验证各从库同步状态、延迟、错误日志(Last_IO_ErrnoLast_SQL_Errno
  • 更新应用配置、DNS、中间件路由规则等,确保后续流量正确打到新主库

整个过程建议在维护窗口内操作,并提前做好回滚预案(如保留原主库 binlog、备份关键位点)。