MongoDB如何正确中断正在创建的索引详解
我们在使用 MongoDB 的时候,会出现需要给一个已经存在的大集合的某个字段增加索引的情况。
索引分为前台索引和后台索引,对应到 pymongo 中创建索引的代码:
import pymongo handler = pymongo.MongoClient().yourdb.yourcol # 前台索引 handler.create_index(‘字段名‘) # 后台索引 handler.create_index(‘字段名‘, background=True)
如果集合里面有很多数据,并且你使用的是前台索引,那么此时,创建索引会把这个集合锁起来,所有对这个集合的写入操作都会挂起。直到索引创建完成为止。如果使用的是后台索引,那么创建索引的过程不会影响数据写入。
但有时候,本来想创建后台索引,却忘记加 background=True参数。此时怎么办?因为大集合创建索引有时候可能需要好几个小时,挂起的写入数据会堆积在内存里面,把内存撑爆。
此时,千万不要重启 MongoDB,因为重启以后,之前没有完成的索引创建操作,依然会自动启动继续创建。
正确的做法是杀掉创建索引的进程。
此时,我们可以在 MongoDB Shell 或者 Robo 3T里面操作。
这里以 Robo 3T为例,首先打开对应的集合,如下图所示:
然后把命令栏里面的内容修改为:
db.currentOp()
返回的内容如下图所示:
创建索引的进程,可以在参数里面看到类似于
"lockType": "write"
这样的字字段。在它附近,可以找到一个字段叫做 opid。
然后在命令栏输入命令:
db.killOp(opid)
杀掉进程。
然后重新创建后台索引即可。
栏 目:其它数据库
本文地址:https://zz.feitang.co/shujuku/32341.html
您可能感兴趣的文章
- 12-20使用DataGrip连接Hive的详细步骤
- 12-20debian10 mariadb安装过程详解
- 12-20MySQL索引失效的几种情况详析
- 12-20详解mysql持久化统计信息
- 12-20Robo可视化mongoDb实现操作解析
- 12-20MySQL 字段 LIKE 多个值
- 12-20Redis fork进程分配不到内存解决方案
- 12-20mysql插入前判断数据是否存在的操作
- 12-20基于navicat连接登录windows10本地wsl数据库
- 12-20Linux安装MariaDB数据库的实例详解


阅读排行
推荐教程
- 12-07mysql存储过程太慢怎么办
- 12-06redis通信协议(protocol)
- 12-05mysql的事务,隔离级别和锁用法实例分析
- 12-04MySQL一次性创建表格存储过程实战
- 12-03深入理解Redis内存淘汰策略
- 12-20PhpMyAdmin出现错误数据无法导出怎么办?
- 12-19Redis中实现查找某个值的范围
- 12-15浅析mysql迁移到clickhouse的5种方法
- 12-15CentOS7 64位下MySQL5.7安装与配置教程
- 12-14Mysql大型SQL文件快速恢复方案分享





