我们在使用 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)

杀掉进程。

然后重新创建后台索引即可。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

P70系列延期,华为新旗舰将在下月发布

3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。

而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?

根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。