贝利信息

mysql主从复制如何切换主库_mysql主从切换流程

日期:2025-12-26 00:00 / 作者:P粉602998670
主库切换需确保从库同步完成:Seconds_Behind_Master=0且复制线程正常;原主库加读锁并记录binlog位点;目标从库停复制、重置配置、关闭read_only;其余从库重新CHANGE MASTER TO新主;最后解锁、验证同步与写入、更新路由。

确认从库已同步完成

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

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

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

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

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

提升从库为新主库

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

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

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

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

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

清理与验证

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

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