mongo集群同步数据异常,手动同步节点副本数据

转载请注明出处:

数据同步方案

当副本集节点的复制进程落后太多,以至于主节点覆盖了该节点尚未复制的 oplog 条目时,副本集节点就会变为"陈旧"。节点跟不上,就会变得"陈旧"。出现这种情况时,必须删除副本集节点的数据,然后执行初始同步,从而完全重新同步该节点。

MongoDB 提供了两种执行初始同步的选项:

  • 第一种:使用空数据目录重新启动 mongod,然后让 MongoDB 的正常初始同步功能恢复数据。这是更简单的选项,但可能需要更长的时间替换数据。

  • 第二种:使用副本集中另一个成员最近的数据目录副本重新启动计算机。此过程可以更快地替换数据,但需要较多的手动步骤。

逻辑初始同步流程

执行逻辑初始同步时,MongoDB 将:

  1. 克隆除本地数据库之外的所有数据库。要进行克隆,mongod 会扫描每个源数据库中的每个集合,然后将所有数据插入自己的这些集合副本中。

  2. 在为每个集合复制文档时构建该集合的所有索引。

  3. 在数据复制过程中拉取新添加的 oplog 记录。确保目标成员在 local 数据库中有足够的磁盘空间,以便在此数据复制阶段期间临时存储这些 oplog 记录。

  4. 将所有更改应用于数据集。mongod 使用来自源的 oplog,更新其数据集以反映副本集的当前状态。

完成初始同步后,节点从 STARTUP2 转换到 SECONDARY

命令查看节点数据同步

通过 rs.status()命令查看mongo集群的数据同步状态,其中主要观察optimeDate字段的值是否能基本保持一致,以及可以查看stateStr中查看状态是否正常。

以下是同步状态异常的服务查看示例:

解决方法

上图中mongo2:27017中的数据状态同步异常,当状态同步异常时,可以先尝试重启mongo,让异常节点去自动同步其他节点的数据。

如果还不能解决,则可以将当前节点的数据库目录文件删除,删除之后再重启整个mongo集群,这样在启动的时候,会自动同步数据。

参考链接

重新同步自管理副本集的成员https://www.mongodb.com/zh-cn/docs/manual/tutorial/resync-replica-set-member/#std-label-replica-set-resync-by-copying

相关推荐
斯普信专业组1 天前
基于k8s环境的mongodb多副本高可用方案
mongodb·容器·kubernetes
SirLancelot11 天前
MongoDB-基本介绍(一)基本概念、特点、适用场景、技术选型
java·数据库·分布式·后端·mongodb·软件工程·软件构建
武子康1 天前
Java-151 深入浅出 MongoDB 索引详解 性能优化:慢查询分析 索引调优 快速定位并解决慢查询
java·开发语言·数据库·sql·mongodb·性能优化·nosql
翰林小院2 天前
【MongoDB】 MongoDB index overview
数据库·mongodb
麦麦麦造2 天前
小小 Postgres,何以替代 Redis、MongoDB 甚至 ES?
redis·mongodb·elasticsearch·postgresql
RunningShare3 天前
高可用架构实战:SpringBoot+MongoDB构建AI原生应用
spring boot·mongodb·架构
喵叔哟3 天前
7. 从0到上线:.NET 8 + ML.NET LTR 智能类目匹配实战--反馈存储与数据治理:MongoDB 设计与运维
运维·mongodb·.net
码界奇点3 天前
平替MongoDB金仓多模数据库在电子证照国产化中的实践与优势
数据库·mongodb·社交电子·里氏替代原则
咖啡Beans4 天前
SpringBoot集成MongoDB使用
spring boot·mongodb
一叶飘零_sweeeet4 天前
从 0 到 1 精通 MongoDB:实战场景 + 底层原理全解析
数据库·mongodb·nosql