承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

教你MongoDB数据库如何正确中断正在创建的索引

管理员 2023-08-15 08:03:42 互联网圈 0 ℃ 0 评论 2112字 收藏

教你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)

杀掉进程。

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

到此这篇关于MongoDB如何正确中断正在创建的索引的文章就介绍到这了,更多相关MongoDB中断正在创建的索引内容请搜索之前的文章或继续浏览下面的相关文章希望大家以后多多支持!

文章来源:丸子建站

文章标题:教你MongoDB数据库如何正确中断正在创建的索引

https://www.wanzijz.com/view/71550.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信