在复制集上创建索引¶
对于复制集而言,从节点会在 primary 结束创建索引后开始创建索引。在 分片集群 上, mongos 会发送 ensureIndex() 方法到每个集群的复制集主节点上,接着在主节点索引创建完毕后从节点开始创建索引。
为了最小化创建索引对在副本集的性能影响,请遵循如下步骤:
注意事项¶
步骤¶
注解
如果您需要在 sharded cluster 上创建索引,请对每个规定了 shard 的复制集重复如下步骤。
停止一个从节点¶
停止一个从节点上的 mongod 进程。重启 mongod 进程, 不要 带 --replSet 选项且指定一个不同的端口。 [1] 限制这个实例是运行在 “standalone” 模式下的。
例如,如果您的 mongod 进程 通常 在默认端口 27017 以选项 --replSet 运行,您就可以使用执行如下命令:
mongod --port 47017
[1] | 通过在不同端口允运行 mongod 的方式,您可以确保复制集的其它成员和所有客户端都不会访问您正在创建索引的成员。 |
创建索引¶
在 mongo shell 里通过 ensureIndex() 方法创建新索引,或者其他您的驱动里的等效方法。这个操作将会在 mongod 实例里建立或者重建索引。
例如,为了在 records 集合的 username 键上创建一个递增索引,可以使用如下 mongo shell 操作:
db.records.ensureIndex( { username: 1 } )
重启 mongod 进程¶
当索引创建完毕,在原有端口上用选项 --replSet 重启 mongod 实例:
mongod --port 27017 --replSet rs0
修改端口数字(例如 27017 )或者复制集名称(例如 rs0 )如果需要的话。
(接着,)在这个成员上跟上(主节点的)复制同步。
Build the Index on the Primary¶
在主节点上创建索引,您可以选择其中一种方式:
在主节点是:doc:后台创建索引 </tutorial/build-indexes-in-the-background> 。
使用 mongo shell 中的 rs.stepDown() 方法让主节点下野(step down),这样主节点平滑地过渡为从节点,且允许复制集选举其他成员为主节点。
然后重启上述索引创建步骤,在(原)主节点上创建索引:
在后台创建索引会比前台方式耗时更久,且会生成不够紧凑的索引 结构。此外,后台创建索引可能会影响主节点的写性能。但是,在后台建立索引允许复制集在MongoDB建立索引期间持续写操作。