Docs 菜单
Docs 主页
/
MongoDB Cluster-to-Cluster Sync
/

验证数据传输

在将应用程序负载从源集群切换到目标集群之前,应验证迁移是否成功。

从 1.9 开始,mongosync 提供嵌入式验证器,可以对源集群和目标集群执行一系列验证检查,以确认同步成功。

您应该在每次同步后验证数据。 如果您计划将应用程序负载从源集群转移到目标集群,这一点非常重要。

验证方法
说明

嵌入式验证程序

从 1.9 开始,mongosync 包含嵌入式验证程序,可对源集群和目标集群运行一系列验证检查,以确认迁移成功。 这是满足要求的部署的首选验证方法。

mongosync进程启动时,它会提示用户有关嵌入式验证程序的免责声明。 您必须接受免责声明,或者如果您已经阅读并确认,请使用mongosync --acceptDisclaimer选项启动 以使用验证程序。

验证程序不会检查迁移的每个方面:

  • 要在不支持的命名空间上验证同步,请使用其他验证方法。

  • 要验证索引同步,请使用索引比较方法。

  • 要验证 元数据同步,请使用 元数据比较 方法。

最基本的验证方法是将源集群上每个同步collection中的文档数量与目标集群上的数量进行比较。

在使用此方法验证数据传输之前,mongosync 必须处于 COMMITTED 状态。

仅当针对具有仅插入工作负载的集群运行时,此方法才会验证同步是否成功。

您可以通过比较从源集群同步到目标集群的collection的 MD5 哈希值来验证同步。

在使用此方法验证数据传输之前,mongosync 必须处于 COMMITTED 状态。

虽然哈希比较可确保目标集群已收到来自源的所有更改,但dbHash 命令会锁定集群,在完成之前阻止其他写入。

无法对分片的集群进行哈希比较。

迁移验证程序连接到源集群和目标集群,并执行一系列验证检查,比较文档、视图和索引,以确认同步成功。

不同类型的数据需要不同的验证方法。您可以使用自定义或手动验证来验证文档索引元数据分片键。

用于验证数据的具体方法取决于应用程序工作负载和数据的复杂性。

后退

遥测

在此页面上