首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用mongomirror同步Atlas中的集合

使用mongomirror同步Atlas中的集合
EN

Stack Overflow用户
提问于 2022-01-20 07:10:44
回答 1查看 787关注 0票数 0

我想迁移一个集从一个蒙戈阿特拉斯集群到另一个。我该怎么做呢?

EN

回答 1

Stack Overflow用户

发布于 2022-01-20 07:10:44

这里有两种可接受的方法:

关闭时间的

  1. 迁移:停止服务,将数据从集合导出到某个第三个位置,然后将数据导入新集群上的新集合,然后恢复服务。
  2. ,但是有一个更好的方法:使用MongoMirror实用程序。使用此实用程序,您可以在不停机的情况下跨集群同步集合。该实用程序首先同步db (或从中选择的集合),然后确保对源的后续写入被同步到dest.

下面是我用来让它运行的语法:

代码语言:javascript
运行
复制
./mongomirror --host atlas-something-shard-0/prod-mysourcedb--shard-00-02-pri.abcd.gcp.mongodb.net:27017 \
   --username myUserName \
   --password PASSWORD \
   --authenticationDatabase admin \
   --destination prod-somethingelse-shard-0/prod-mydestdb-shard-00-02-pri.abcd.gcp.mongodb.net:27017 \
   --destinationUsername myUserName \
   --destinationPassword PASSWORD \
   --includeNamespace dbname.collection1 \
   --includeNamespace dbname.collection2 \
   --ssl \
   --forceDump

不幸的是,这里有许多陷阱:

  1. 确保用户具有正确的角色。这实际上是在文档中讨论的,因此请仔细阅读相关部分。
  2. 要正确指定主机和目标字段,您需要同时获得RS名称和主实例名称。获得这些信息的一种方法是使用mongosh工具并在源集群和目标集群上运行rs.conf()。RS名称在命令的输出中被指定为"_id“,实例在输出中被列为”成员“。您将需要接受主实例的“host”字段。最终结果应该类似于您指定副本集的RS-name/primary-instance-host:port
  3. IF,您必须指定主实例。如果不这样做,将导致一个模糊的错误(EOF something).
  4. I建议添加forceDump标志(至少直到您设法使它第一次运行为止)。如果您指定了不存在的集合,则该实用程序只会给出它们不存在的一个指示,然后继续“同步”这些,而不是失败。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70782038

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档