killOp功能
通过操作id, 停止正在运行的操作。如数据库的增删改查操作, aggregation操作等。
语法
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参数查看分片集群中正在运行的操作。
权限控制
使用举例
db.adminCommand({"killOp": 1, "op": 3478})
//返回
{"info": "attempting to kill op", "ok": 1}
killOp与killCusors
两者针对的对象不同。killOp针对的是数据库操作, 包括查询,修改,集合处理, 构建索引等动作。 cursor是通过查询返回的结果指针, mongodb已经完成了查询动作,通过cursor将数据库查询结果分批返回给客户端。