MongoDB创建索引
一、后台创建索引
默认情况下,当我们对一个比较热点的集合创建索引时,直到索引创建完毕,该集合都是无法读写的。
1、后台创建索引语法
db.collection.createIndex( { filed: 1 }, { background: true } )
2、后台创建索引行为以及资源消耗
1)当使用后台创建索引时,不会阻塞对该集合的读写操作,但是在索引创建完成之前,会阻塞对该集合别的创建索引操作。
2)在创建索引期间,查询不会使用到未创建完毕的索引
3)MongoDB后台创建索引使用一种增量创建的办法,相对前台创建索引是要慢的,特别是当创建索引所需内存超过RAM的时候,尽量选择一个业务低峰期的时间窗口来做创建索引的操作
4)在创建索引时,如果达到了内存的限制,MongoDB会使用磁盘临时表,mongodb默认对内存使用的限制为500MB,也可以通过参数maxIndexBuildMemoryUsageMegabytes进行设置
5)在创建索引时候,如果mongod意外宕机导致创建索引中断,mongod服务默认重新启动后会前台重新创建索引,若在创建索引时报错,mongod程序会报错退出,可设置storage.indexBuildRetry参数控制mongod重启后是否前台重试创建索引。
二、单机/副本集下如何创建索引
1、单机
1)使用前台创建索引,创建索引期间需要持有global DB lock,阻塞所有读写操作
2)使用后台创建索引,创建索引期间不需要持有global DB lock,不会阻塞读写操作
2、副本集
1)在primary节点使用前台创建索引,primary节点在创建索引期间需要一个global DB lock,阻塞所有读写操作;secodary节点的复制线程在复制创建索引操作时也会持有global DB lock,阻塞对secondary节点的所有读操作。
2)在primary节点使用后台创建索引,primary节点和secondary节点在创建索引期间不需要global DB lock,不会阻塞该节点正常操作。
3)在副本集中最大程度减少创建索引对业务的影响,我们可以使用以下方法创建索引:
1.停止其中一个secondary节点并以单机模式启动
2.在该secondary节点创建索引,
3.重新以副本集模式启动该secondary节点
4.重复以上步骤对其他的secondary节点进行创建索引
5.将primary节点退位为seconary节点并创建索引
rs.stepDown()
4)在副本集模式创建索引的一些注意点
1.如果单机模式创建唯一索引,需要停止对该集合的写入操作;否则推荐使用 db.collection.createIndex()创建索引。
2.在副本集创建索引时,需要保证secondary节点的oplog足够大,以便在创建索引成功后追上primary节点的同步。