MongoDB创建索引

太阳2年前技术文章977

一、后台创建索引

默认情况下,当我们对一个比较热点的集合创建索引时,直到索引创建完毕,该集合都是无法读写的。

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节点的同步。


相关文章

Hive压测之开源Hive基准测试工具(hive-testbench-hive14)

Hive压测之开源Hive基准测试工具(hive-testbench-hive14)

此文章禁止转载概述Hive基准测试工具工具,可用来造数测试Hive基本性能。TPC-DS:提供一个公平和诚实的业务和数据模型,99个案例TPC-H:面向商品零售业的决策支持系统测试基准,定义了8张表,...

CDP实操--动态启停服务

以yarn nodemanager 为例获取role yarn nodemanager:curl -u admin:admin 'http://172.16.106.151:7180/api/v1/c...

WAF 透明接入模式

WAF 透明接入模式

透明接入模式只需将需要防护的网站信息添加到WAF,无需修改域名的DNS解析设置,即可实现WAF防护。如果您的源站服务器为ECS服务器或者部署在阿里云公网SLB上,那么除了使用CNAME接入模式,还可以...

MySQL运维实战之ProxySQL(9.4)proxysql和后端MySQL自动切换

MySQL运维实战之ProxySQL(9.4)proxysql和后端MySQL自动切换

如上图架构,当后端MySQL主库出现问题,发生主备切换后,如何自动将ProxySQL的读写切换到新的主库上?可以通过mysql_replication_hostgroups表配置实现:insert&n...

两款方案详解,企业线下数据库迁移至云上ScyllaDB(2)

方案二通过在集群中添加新数据中心的方式,进行数据迁移。然后下线集群老的数据中心。1. 集群添加新数据中心1.1. 先决条件收集现有集群信息:cat /etc/scylla...

NameSpaces状态一直为Terminating

NameSpaces状态一直为Terminating

问题描述删除ingress-nginx后发现ingress-nginx的命名空间一直为销毁中,大致查看了下发现命名空间中已经没有其他资源。该状态已经持续了十几个小时强制删除命名空间```Plain T...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。