如何在mysql中迁移多源复制

P粉602998670
发布: 2025-11-08 18:11:03
原创
781人浏览过
多源复制迁移需确保数据一致与拓扑清晰。1. 明确各主库的连接信息、GTID状态及复制通道命名;2. 配置新从库的唯一server-id,启用relay_log_recovery和gtid_mode;3. 使用mysqldump加--single-transaction等参数导出各主库数据,若使用GTID则启用--set-gtid-purged=ON;4. 分别导入数据至目标实例并配置CHANGE MASTER TO指定CONNECTION_NAME建立多通道复制,确保每个主库对应独立通道,最终启动复制并验证同步状态。

如何在mysql中迁移多源复制

MySQL 多源复制迁移需确保数据一致性、拓扑结构清晰,并正确配置主从关系。以下是具体操作步骤与关键点。

理解多源复制架构

多源复制指一个从库(Slave)接收来自多个主库(Master)的数据变更。常用于数据汇总场景,如将多个业务库的数据同步到分析库。迁移此类结构时,需明确现有主从关系、GTID 使用情况及复制通道命名。

每个主库对应一个独立的复制通道,通过 CHANGE MASTER TO 命令指定 CONNECTION_NAME 区分。迁移前应记录各主库的主机地址、端口、用户权限、binlog 位置或 GTID 信息。

准备目标实例并导出数据

在新从库部署 MySQL 实例,确保版本兼容性(建议相同大版本)。启用 multi-source 复制支持:设置 server-id 唯一,开启 relay_log_recovery 和 gtid_mode(若原环境使用 GTID)。

  • 使用 mysqldump 对每个主库分别导出数据,推荐加上 --single-transaction --master-data=2 --routines --triggers 参数保证一致性
  • 若启用 GTID,添加 --set-gtid-purged=ON,使 dump 文件包含 GTID_EXECUTED 信息
  • 导入时按主库分别执行 mysql -h new_slave -u root -p db_name

配置新从库的多源复制通道

登录新从库,为每个主库创建独立复制链路。以主库 A 和 B 为例:

  • CHANGE MASTER TO MASTER_HOST='master_a_host', MASTER_USER='repl', MASTER_PASSWORD='pass', MASTER_AUTO_POSITION=1 FOR CHANNEL 'master_a';
  • CHANGE MASTER TO MASTER_HOST='master_b_host', MASTER_USER='repl', MASTER_PASSWORD='pass', MASTER_AUTO_POSITION=1 FOR CHANNEL 'master_b';

若未使用 GTID,则需指定 MASTER_LOG_FILE 和 MASTER_LOG_POS。启动复制:START SLAVE FOR CHANNEL 'master_a'; START SLAVE FOR CHANNEL 'master_b';

柒源写作
柒源写作

降AI率;降重复率;一键初稿;一键图表

柒源写作 44
查看详情 柒源写作

检查状态:SHOW SLAVE STATUS FOR CHANNEL 'master_a'\G,确认 Seconds_Behind_Master 和 IO/SQL 线程运行正常。

验证与切换

监控复制延迟和错误日志,确认无 SQL 线程报错(如主键冲突、表不存在等)。可对比关键表行数或校验和验证数据一致性。

应用连接切换至新从库前,建议暂停写入主库或设置只读,确保最终同步完成。切换后持续观察一段时间,确认复制稳定。

基本上就这些。关键是逐通道配置、保持 GTID 或日志位置准确,以及迁移前后数据核对。

以上就是如何在mysql中迁移多源复制的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号