利用mongosync做数据库迁移

本文介绍了在mongos集群环境下,如何利用mongosync工具进行数据库的跨机房迁移。详细步骤包括在目标机房重建集群、停用源机房负载均衡、全量+增量同步数据、设置分片信息以及最终切换业务IP。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

有些情况下,官方推荐的迁移方法不是那么便捷,比如mongos集群的整体迁移步骤非常繁琐,且对网络的要求很高;

mongosync支持mongos集群迁移,目前支持3.0及以下版本,特别适合mongodb跨机房的迁移

目前有这么一个需求

机房A有一套mongos集群,需要迁移到机房B,A和B之间的mongo实例网络不通,但是在其中一个中转服务器上能够分别ping通A机房和B机房的mongodb实例,于是我采用360开发的开源迁移工具mongosync


步骤

1 在B机房建立和A机房相同配置的mongos集群

2 A机房mongos停止负载均衡器

3 mongosync全量+增量同步

4 等待两端集群数据完成同步后,在B机房设置sharding信息,比如哪个表的哪个字段参与sharding

5 A机房mongos集群业务停服

6 确认数据完全同步后,应用层将业务ip改为B机房的mongos ip

7 迁移完成


mongosync的安装和使用方法

系统版本  centos 7.2  python 2.7.5  gcc 4.8.5

安装方法

1 git clone https://github.com/jacketwoo/mongosync

2 yum install -y scons

3 yum install -y boost boost-devel

4 yum install -y openssl-devel

5 cd mongosync/

6 make

使用方法(全量+增量+mongos)

nohup ./mongosync --src_srv 10.6.13.140:27000 --src_user ucloudbackup --src_

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值