默认情况下,ensureIndex()是阻塞型操作,并会暂停数据库上所有正在进行的其他操作,直到创建索引完成。但是,在高于或等于版本1.3.2的mongodb中,提供了可选的后台创建索引的选项。
要在后台创建索引,增加background:true选项。例如:
> db.things.ensureIndex({x:1}, {background:true});
> db.things.ensureIndex({name:1}, {background:true, unique:true,
... dropDups:true});
当后台模式启动时,其他的操作,包含写,在创建索引期间不会被阻塞。该索引在创建完成前不会被应用到查询中去。
尽管该操作是“后台”类型意味着其他操作可以并发执行,但是该命令在创建完成前不会立即返回到shell提示符。要同时执行其他操作,可以另外打开一个mongo shell实例。
需要注意的是,后台模式创建索引是新增加的方法,它比默认的前端模式要慢:需要更多的时间来创建索引。
在创建索引过程中,可以通过db.currentOp()命令查看到该操作依旧在进行中(显示为对system.indexes的插入操作)。你可以使用db.killOp()来终止创建过程。
在创建索引过程中,该索引在system.indexes中是可见的,但是创建完成前它不会被用到查询操作中。
注意:
- 每个集合在同一时刻只允许创建一个索引。
- 一些管理操作,如repairDatabase,不允许在后台创建索引期间使用。
- (应用到生产环境,应使用)v1.4或者更高版本。