【MongoDB】配置Secondary(从节点) 的 Sync Target(复制源)

一 概述

从节点 从 主节点捕获数据以保持副本集数据的最新副本。然而,默认情况下,从节点可能会根据成员之间的ping时间变化和其他成员的复制状态自动更改其同步目标。请参阅"副本集数据同步"和"管理链式复制"以获取更多信息。

对于某些部署,实施自定义复制同步拓扑可能比默认的同步目标选择逻辑更有效。MongoDB提供了指定主节点的能力。

要临时覆盖默认的同步目标选择逻辑,可以手动配置从节点的同步目标,以临时拉取oplog条目。以下方式可以访问此功能:

  1. replSetSyncFrom 命令,或
  2. rs.syncFrom()

二 注意事项

1 同步逻辑

版本3.4中更改

如果在运行 replSetSyncFrom 或 rs.syncFrom() 时初始同步操作正在进行中,replSetSyncFrom/rs.syncFrom()会停止正在进行的初始同步,并使用新目标重新启动同步过程。在先前的版本中,如果在初始同步期间运行replSetSyncFrom/rs.syncFrom(),MongoDB不会产生错误消息,但同步目标将在初始同步操作完成后才会更改。

仅在必要时修改默认同步逻辑,并始终谨慎行事。

2 目标

同步的成员必须是集合中有效的数据源。要从某个成员进行同步,该成员必须:

  1. 拥有数据。它不能是仲裁者,不能处于启动或恢复模式,并且必须能够响应数据查询。
  2. 可访问。
  3. 是副本集配置中同一集合的成员。
  4. 使用membersn.buildIndexes设置构建索引。
  5. 是集合中的不同成员,以防止从自身进行同步。 如果尝试从落后当前成员超过10秒的成员进行复制,mongod会记录警告,但仍会从落后的成员进行复制。

3 持久性

replSetSyncFrom/rs.syncFrom()提供对默认行为的临时覆盖。mongod将在以下情况恢复为默认同步行为:

  1. mongod实例重新启动。
  2. mongod与同步目标之间的连接关闭。
  3. 如果同步目标比副本集中的另一个成员落后超过30秒。

过程

在mongo shell中使用replSetSyncFrom命令:

bash 复制代码
db.adminCommand( { replSetSyncFrom: "hostname<:port>" } );
bash 复制代码
rs.syncFrom("hostname<:port>");
相关推荐
●VON3 小时前
鸿蒙Flutter实战:分类管理页BottomSheet CRUD
数据库·flutter·华为·harmonyos·鸿蒙
Cosolar3 小时前
Chroma向量库面试学习指南
数据库·人工智能·面试·职场和发展·数据库架构
企服AI产品测评局5 小时前
Agent适配信创环境实测:企业级自动化如何实现国产操作系统与数据库全兼容?
运维·数据库·人工智能·ai·chatgpt·自动化
cfm_29145 小时前
Redis数据安全性解析
数据库·redis·缓存
DIY源码阁5 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
NiceCloud喜云6 小时前
Claude Code Routines 实战:三种触发器跑通云端自动化编码
android·运维·数据库·人工智能·自动化·json·飞书
辞忧九千七6 小时前
Redis 单机一主二从主从复制完整搭建指南
数据库·redis·缓存
lzhdim7 小时前
SQL 入门 16:SQL 事务隔离级别与死锁解析(易懂)
数据库·sql
AI 小老六8 小时前
Claude Code 如何压缩上下文:Microcompact、Prompt Cache 与 cache_edits 工程拆解
数据库·人工智能·ai·语言模型·架构·系统架构
Chasing__Dreams8 小时前
Redis--基础知识点--32--redis底层存储结构
数据库·redis·缓存