这篇文章主要给大家介绍了关于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为例,首先打开对应的集合,如下图所示:
然后把命令栏里面的内容修改为:
1db.currentOp()
返回的内容如下图所示:
创建索引的进程,可以在参数里面看到类似于
1"lockType": "write"
这样的字字段。在它附近,可以找到一个字段叫做 opid。
然后在命令栏输入命令:
1db.killOp(opid)
杀掉进程。
然后重新创建后台索引即可。
到此这篇关于MongoDB如何正确中断正在创建的索引的文章就介绍到这了,更多相关MongoDB中断正在创建的索引内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持50站长网!
2、若您的网站或机构从本站获取的一切资源进行商业使用,除来源为本站的资料需与本站协商外,其他 资源请自行联系版权所有人。
3、本站不保证资源的准确性、安全性和完整性,请您在阅读、下载及使用过程中自行确认,本站亦不承 担上述资源对您或您的网站造成的任何形式的损失或伤害
4、未经本站允许,不得盗链、盗用本站资源;不得复制或仿造本网站,不得在非本站所属的服务器上建 立镜像,本站对其自行开发的或和他人共同开发的所有内容、技术手段和服务拥有全部知识产权,任何 人不得侵害或破坏,也不得擅自使用。
5、互联网的本质是自由与分享,我们真诚的希望,每一份有价值的正能量能够在互联网中自由传播,能 够为每一个网站提供动力。
本文链接:https://www.50zhan.com/post/13078.html
- 上一篇: 2020年最火的6种编程语言推荐
- 下一篇: PostgreSQL COALESCE使用方法代码解析
发表评论