MongoDB当前操作db.currentOp()示例

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介:

2000元阿里云代金券免费领取,2核4G云服务器仅664元/3年,新老用户都有优惠,立即抢购>>>


阿里云采购季(云主机223元/3年)活动入口:请点击进入>>>,


阿里云学生服务器(9.5元/月)购买入口:请点击进入>>>,

停止某个操作:

$ mongo --port 17380   
MongoDB shell version: 2.4.5    
connecting to: 127.0.0.1:17380/test    
mongos> db.currentOp()    
{ "inprog" : [ ...] }

mongos> db.killOp("shard0001:163415563")


批量停止:

1
db.currentOp().inprog.forEach( function (item){db.killOp(item.opid)})

当查询超过1000秒的,停止:

1
db.currentOp().inprog.forEach( function (item){ if (item.secs_running > 1000 )db.killOp(item.opid)})

停止某个数据源的查询:

1
db.currentOp().inprog.forEach( function (item){ if (item.ns ==  "cswuyg.cswuyg" )db.killOp(item.opid)})

把所有在等待锁的操作显示出来:

1
db.currentOp().inprog.forEach( function (item){ if (item.waitingForLock)print(JSON.stringify(item))})

把处于等待中的分片显示出来:

1
db.currentOp().inprog.forEach( function (item){ if (item.waitingForLock){print(item.opid.substr(0,9));print(item.op);}})

把非等待的分片显示出来:

1
db.currentOp().inprog.forEach( function (item){ if (!item.waitingForLock){ var  lock_info = item[ "opid" ];print(lock_info.substr(0,9));print(item[ "op" ]);}})

查找所有的查询任务:

1
db.currentOp().inprog.forEach( function (item){ if (item.op== "query" ){print(item.opid);}})

查找所有的非查询任务:

1
db.currentOp().inprog.forEach( function (item){ if (item.op!= "query" ){print(item.opid);}})

查找所有的操作:

1
db.currentOp().inprog.forEach( function (item){print(item.op, item.opid);});

 

常用js脚本,可直接复制到mongo-shell下使用:

 

显示当前所有的任务状态:

1
2
print( "##########" );db.currentOp().inprog.forEach( function (item){ if (item.waitingForLock){ var  lock_info = item[ "opid" ];print( "waiting:" ,lock_info,item.op,item.ns);}});print
( "----" );db.currentOp().inprog.forEach( function (item){ if (!item.waitingForLock){ var  lock_info = item[ "opid" ];print( "doing" ,lock_info,item.op,item.ns);}});print( "##########" );

 

杀掉某些特定任务:

(1)

1
2
db.currentOp().inprog.forEach( function (item){ if (item.waitingForLock){ var  lock_info = item[ "opid" ]; if (item.op== "query"  && item.secs_running >60 && item.ns== "cswuyg.cswuyg" )
{db.killOp(item.opid)}}})

(2)

1
2
3
4
5
6
7
db.currentOp().inprog.forEach( function (item) {   
  var  lock_info = item[ "opid" ];    
  if  (item.op ==  "query"  && item.secs_running > 1000) {    
   print( "kill" , item.opid);    
   db.killOp(item.opid)    
  }    
})

















本文转自UltraSQL51CTO博客,原文链接:http://blog.51cto.com/ultrasql/1706903  ,如需转载请自行联系原作者







相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
5天前
|
NoSQL MongoDB Python
深入了解 Python MongoDB 操作:排序、删除、更新、结果限制全面解析
使用 sort() 方法对结果进行升序或降序排序。 sort() 方法接受一个参数用于“字段名”,一个参数用于“方向”(升序是默认方向)。
73 0
|
3天前
|
JSON NoSQL MongoDB
实时计算 Flink版产品使用合集之要将收集到的 MongoDB 数据映射成 JSON 对象而非按字段分割,该怎么操作
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
31 1
|
5天前
|
NoSQL 数据处理 MongoDB
MongoDB查询操作深度剖析
【4月更文挑战第30天】本文深入探讨了MongoDB查询操作,包括查询语法、优化及高级技巧。使用`find()`方法进行查询,如`db.users.find({ age: { $gt: 25 } })`找年龄大于25的用户。优化查询性能涉及创建索引、使用复合索引和避免全表扫描。高级查询涵盖聚合管道、文本搜索和地理空间查询,提供复杂数据处理和地理位置查询能力。理解并应用这些知识能提升MongoDB的使用效率和应用性能。
|
5天前
|
存储 NoSQL Go
【Go语言专栏】Go语言中的MongoDB操作与NoSQL应用
【4月更文挑战第30天】本文介绍了Go语言中操作MongoDB的方法和NoSQL应用的优势。MongoDB作为流行的NoSQL数据库,以其文档型数据模型、高性能和可扩展性被广泛应用。在Go语言中,通过mongo-go-driver库可轻松实现与MongoDB的连接及插入、查询、更新和删除等操作。MongoDB在NoSQL应用中的优点包括灵活的数据模型、高性能、高可用性和易于扩展,使其成为处理大规模数据和高并发场景的理想选择。
|
5天前
|
分布式计算 DataWorks NoSQL
DataWorks产品使用合集之DataWorks 集成工具是否支持对 MongoDB 的单字段更新操作
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
42 0
|
5天前
|
NoSQL MongoDB
MongoDB代码操作
MongoDB代码操作
|
5天前
|
NoSQL MongoDB 数据库
MongoDB黑窗口操作(CRUD)
MongoDB黑窗口操作(CRUD)
|
5天前
|
缓存 NoSQL 关系型数据库
【MongoDB】MongoDB更新操作时是否立刻fsync到磁盘?
【4月更文挑战第2天】【MongoDB】MongoDB更新操作时是否立刻fsync到磁盘?
|
5天前
|
消息中间件 NoSQL Kafka
云原生最佳实践系列 5:基于函数计算 FC 实现阿里云 Kafka 消息内容控制 MongoDB DML 操作
该方案描述了一个大数据ETL流程,其中阿里云Kafka消息根据内容触发函数计算(FC)函数,执行针对MongoDB的增、删、改操作。
|
5天前
|
机器学习/深度学习 自然语言处理 NoSQL
http://www.vxiaotou.com