从节点 从 主节点捕获数据以保持副本集数据的最新副本。然而,默认情况下,从节点可能会根据成员之间的ping时间变化和其他成员的复制状态自动更改其同步目标。请参阅“副本集数据同步”和“管理链式复制”以获取更多信息。
对于某些部署,实施自定义复制同步拓扑可能比默认的同步目标选择逻辑更有效。MongoDB提供了指定主节点的能力。
要临时覆盖默认的同步目标选择逻辑,可以手动配置从节点的同步目标,以临时拉取oplog条目。以下方式可以访问此功能:
replSetSyncFrom 命令,或rs.syncFrom()
版本3.4中更改
如果在运行 replSetSyncFrom 或 rs.syncFrom() 时初始同步操作正在进行中,replSetSyncFrom/rs.syncFrom()会停止正在进行的初始同步,并使用新目标重新启动同步过程。在先前的版本中,如果在初始同步期间运行replSetSyncFrom/rs.syncFrom(),MongoDB不会产生错误消息,但同步目标将在初始同步操作完成后才会更改。
仅在必要时修改默认同步逻辑,并始终谨慎行事。
同步的成员必须是集合中有效的数据源。要从某个成员进行同步,该成员必须:
replSetSyncFrom/rs.syncFrom()提供对默认行为的临时覆盖。mongod将在以下情况恢复为默认同步行为:
过程
在mongo shell中使用replSetSyncFrom命令:
db.adminCommand( { replSetSyncFrom: "hostname<:port>" } );
rs.syncFrom("hostname<:port>");