重建MySQL从库的核心思路是用主库一致快照加新binlog位置重新初始化复制。需先执行SHOW MASTER STATUS获取位点,再用mysqldump --single-transaction --master-data=2导出数据,最后清空从库并导入备份。

重建 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
CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000012', MASTER_LOG_POS=154; 的行停止从库复制进程:
STOP SLAVE;
清空从库所有数据(生产环境务必提前备份):
然后导入主库备份:
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_Running 和 Slave_SQL_Running 均为 Yes,且 Seconds_Behind_Master 逐步归零。
以上就是mysql主从复制如何重建从库_mysql从库重建流程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号