本文介绍: 与关系型数据库类似, mongodb执行查询语句修改数据,建立索引操作过程中,会占用大量的cpu内存资源mongodb提供了各种各样的监控工具命令监控数据库状态运行效率。当用户提交查询语句影响数据库性能时,需要及时清理mongodb提供了killOp命令,来清理这些操作。

        与关系型数据库类似, mongodb执行查询语句修改数据,建立索引的操作过程中,会占用大量的cpu内存的资源。mongodb提供了各种各样的监控工具命令监控数据库状态运行效率。当用户提交的查询语句影响数据性能时,需要及时清理。

        mongodb提供了killOp命令,来清理这些操作。

killOp功能

        通过操作id, 停止正在运行的操作。如数据库的增删改查操作, aggregation操作等。

        使用killOp停止运行命令时,需要admin数据库下执行。其中操作id通过$currentOpdb.currentOp()获得。killOp方法通过db.runCommand({<command>})调用使用killOp操作需要谨慎,仅用于停止用户客户端产生的数据库操作。禁止停止数据库内部操作。

语法

db.adminCommand({
	killOp: 1,
  op: <opid>,
  comment: <any>
})

        其中, 数字类型参数op表示操作id使用$currentOp或db.currentOp()获得, comment是此次操作的备注信息,用户添加备注信息以后,可以在下面三个地方看到

        禁止在replicaset和分片集群中使用killOp停止正在构建索引。停止索引构建需要再主节点使用dropIndexes命令

分片集群中使用killOp

权限控制

使用举例

db.adminCommand({"killOp": 1, "op": 3478})

//返回
{"info": "attempting to kill op", "ok": 1}

        当mongodb标记操作3478可以停止的时候, 返回 ok, 但实际上可能并没有立即停止指定运行。 mongodb需要找到一个合适的时间点, 停止当前操作。使用$currentOp或db.currentOp()确认当前操作是否真的停止。

killOp与killCusors

        两者针对对象不同。killOp针对的是数据库操作, 包括查询,修改,集合处理构建索引动作cursor是通过查询返回结果指针, mongodb已经完成了查询动作,通过cursor将数据库查询结果分批返回客户端。

原文地址:https://blog.csdn.net/wilsonzane/article/details/134707053

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_17807.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注