mysql主从复制如何重建从库_mysql从库重建流程

来源:这里教程网 时间:2026-02-28 20:31:35 作者:

重建 MySQL 从库的核心思路是:**用主库当前一致的数据快照 + 新的 binlog 位置,重新初始化从库复制**。关键不在于“删掉重来”,而在于确保主从数据起点一致、复制坐标准确。

一、确认主库状态并获取同步位点

登录主库,执行:

SHOW MASTER STATUS;

记录 File(当前 binlog 文件名)和 Position(当前写入位置)。这是从库后续 START SLAVE 必须指向的起点。注意:该命令结果仅反映当前状态,若主库写入频繁,需配合锁表或使用一致性备份工具(如 mysqldump --single-transaction)来保证逻辑一致性。

二、安全导出主库数据(推荐逻辑备份)

在主库上执行(避免锁表影响业务):

mysqldump --all-databases --single-transaction --master-data=2 --routines --triggers > full_backup.sql
--single-transaction:对 InnoDB 表启用一致性快照,无需全局读锁 --master-data=2:在 dump 文件中以注释形式记录导出时刻的 binlog 文件和位置(比手动记更可靠) 导出后检查文件头部,找到类似
CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000012', MASTER_LOG_POS=154;
的行

三、清理并重建从库实例

停止从库复制进程:

STOP SLAVE;

清空从库所有数据(生产环境务必提前备份):

停掉 MySQL 服务 删除 data 目录下除 mysql 系统库外的所有数据库目录(或直接删 data 目录后重新初始化) 重启 MySQL,确保实例干净启动

然后导入主库备份:

mysql < full_backup.sql

四、配置并启动复制

登录从库,执行 CHANGE MASTER 命令(使用 dump 文件中注释的位点,或你手动记录的位点):

CHANGE MASTER TO
  MASTER_HOST='主库IP',
  MASTER_USER='repl_user',
  MASTER_PASSWORD='xxx',
  MASTER_PORT=3306,
  MASTER_LOG_FILE='mysql-bin.000012',
  MASTER_LOG_POS=154;

启动复制:

START SLAVE;

验证状态:

SHOW SLAVE STATUS\G

重点检查:Slave_IO_RunningSlave_SQL_Running 均为 Yes,且 Seconds_Behind_Master 逐步归零。

相关推荐