网站备案通讯地址,济南做网站优化的公司,唯样商城网站,富阳有没有做网站的与关系型数据库类似#xff0c; mongodb在执行查询语句#xff0c;修改数据#xff0c;建立索引的操作过程中#xff0c;会占用大量的cpu#xff0c;内存的资源。mongodb提供了各种各样的监控工具和命令#xff0c;监控数据库状态和运行效率。当用户提交的查询语句影响数… 与关系型数据库类似 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.commentDatabase profiler输出结果在字段command.commentcurrentOp输出结果在字段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将数据库查询结果分批返回给客户端。