Mongodb使用killOp停止正在执行的操作

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

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

killOp功能

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

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

语法

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

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

  • mongodb日志,在字段attr.command.cursor.comment
  • Database profiler输出结果,在字段command.comment
  • currentOp输出结果,在字段command.comment

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

分片集群中使用killOp

  • 分片集群中,在mongos中使用killOp停止读操作,mongodb也会停止分布于其他分片的查询语句
  • 分片集群中,使用killOp停止写操作时,只会停止当前节点的操作,不会派发到其他节点。
  • 通过$currentOp命令的localOps参数查看分片集群中正在运行的操作。

权限控制

  • 通过验证登录到数据库,用户需要带有killop权限,才运行停止mongodb的操作
  • 在运行mongod的服务器实例上,用户停止自己创建的数据库操作,无需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将数据库查询结果分批返回给客户端。

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

威赞

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值