replSetSyncFrom

在本页面

Description

  • replSetSyncFrom
    • 临时覆盖当前mongod的默认同步目标。此操作对于测试不同的模式以及在集合成员未从所需主机复制的情况下很有用。

在版本 3.2 中更改:具有1 vote的 MongoDB 3.2 副本集成员不能与具有0 votes的成员同步。

admin数据库中运行replSetSyncFrom

replSetSyncFrom命令的格式如下:

db.adminCommand( { replSetSyncFrom: "hostname<:port>" })

replSetSyncFrom命令具有以下字段:

FieldTypeDescription
replSetSyncFromstring该成员应从其复制的副本集成员的名称和端口号。使用[hostname]:[port]表格。


在版本 3.2 中进行了更改:具有1 vote的 MongoDB 3.2 副本集成员无法与具有0 votes的成员同步。

Behavior

Sync Logic

在版本 3.4 中更改。

如果在运行replSetSyncFrom时正在进行初始同步操作,则replSetSyncFrom会停止进行中的初始同步并重新启动与新目标的同步过程。在以前的版本中,如果您在初始同步期间运行replSetSyncFrom,则 MongoDB 不会产生任何错误消息,但是同步目标直到初始同步操作之后才会更改。

仅根据需要修改默认的同步逻辑,请务必谨慎。

Target

要同步的成员必须是集合中数据的有效来源。要从成员同步,成员必须:

  • 有数据。在启动或恢复模式下,它不能是仲裁器,并且必须能够回答数据查询。

  • Be accessible.

  • 成为副本集配置中同一集合的成员。

  • 使用members[n].buildIndexes设置构建索引。

  • 集合中的其他成员,以防止与其自身进行同步。

如果您尝试从比当前成员晚 10 秒以上的成员进行复制,则mongod将记录警告,但仍将从滞后成员复制。

Persistence

replSetSyncFrom提供默认行为的临时替代。在以下情况下,mongod将恢复为默认的同步行为:

  • mongod实例重新启动。

  • mongod与同步目标之间的连接关闭。

  • 如果同步目标比副本集的另一个成员落后 30 秒以上。

有关使用replSetSyncFrom的更多信息,请参见配置辅助节点的同步目标