MongoDB 了解正在进行的操作
1.1 查看正在进行的操作
使用db.currentOp()函数:
>db.currentOp()
1、opid 这是操作的唯一标识符,可以通过它来终止操作
2、active 表示操作是否正在进行。如果为false表示操作已交出或正在等其他操作交出锁
3、secs_running 表示该操作已经执行的时间。可通过她判断哪些查询耗时过长,或者占用了过多的数据库资源
4、op 表示操作类型
5、desc 该值与日志(log)信息联系起来。日志中与此连接相关的每一天记录都会以[conn3]为前缀,因此可以
以此来筛选相关的日志信息
6、locks 描述该操作使用的锁的类型。其中"^"表示全局锁
7、waitingForLock 表示该操作是否因正在等待其他操作交出锁而处于阻塞状态
8、numYields 表示该操作交出锁(yield),而使其他操作得以运行的次数。通常进行文档搜索的操作(查询、更新和删除)可以交出锁。只有在其他操作队列等待该操作所持的锁时,它才会交出自己的锁。简单来讲,如果没有其他操作处于waitingForLock状态,则该操作不会交出锁。
9、lockstats.timeAcquiringMicros 表示该操作需要多长时间才能取得所需的锁


1.2 db.currentOp()中添加过滤条件
把查询的条件作为参数传入函数来进行过滤
>db.currentOp({"ns":"prod.users"})
对于currentOp中的任何字段都可以查询,使用普通的查询语句即可
1.3 寻找有问题的操作

1.4 终止操作执行
>db.killoP(123)
并非所有操作都能终止。一般来讲,只有交出了锁的进程才能终止,正在占用锁,或正在等待其他操作交出锁的操作则通常无法被终止。
如果向一个操作发出了"kill"信号,那么它在db.currentOp的输出中就会有一个killed字段。然而,只有从当前操作列表中消失后,他才真正的被终止。
1.5 假象
避免终止mongoDB自身进程

1.6 避免幽灵操作

MongoDB 了解正在进行的操作的更多相关文章
- 【翻译】MongoDB指南/CRUD操作(二)
[原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(二) 主要内容: 更新文档,删除文档,批量写操作,SQL与MongoDB映射图,读隔离(读关 ...
- 【翻译】MongoDB指南/CRUD操作(一)
[原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(一) 主要内容:CRUD操作简介,插入文档,查询文档. CRUD操作包括创建.读取.更新和删 ...
- MongoDB的CRUD操作
1. 前言 在上一篇文章中,我们介绍了MongoDB.现在,我们来看下如何在MongoDB中进行常规的CRUD操作.毕竟,作为一个存储系统,它的基本功能就是对数据进行增删改查操作. MongoDB中的 ...
- MongoDB各种查询操作详解
这篇文章主要介绍了MongoDB各种查询操作详解,包括比较查询.关联查询.数组查询等,需要的朋友可以参考下 一.find操作 MongoDB中使用find来进行查询,通过指定find的第一个参数可 ...
- mongodb的常用操作
对于nosql之前工作中有用到bekerlydb,最近开始了解mongodb,先简单写下mongodb的一些常用操作,当是个总结: 1.mongodb使用数据库(database)和集合(collec ...
- MongoDB基本命令行操作
1. 连接MongoDB: Mongodb://username:password@hostname/dbname 2. 创建数据库: use dbname:如果数据库不存在则创建数据库,否则切换到指 ...
- mongoDB之集合操作
mongoDB之集合操作 mongoDB中的集合相当于mysql中的表. mongoDB中集合的创建: 第一种方式:不限制集合大小 db.createCollection("集合名称&q ...
- MongoDB数据库简单操作
之前学过的有mysql数据库,现在我们学习一种非关系型数据库 一.简介 MongoDB是一款强大.灵活.且易于扩展的通用型数据库 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数 ...
- Yii2的mongodb的聚合操作
最近项目使用到mongodb的聚合操作,但是yii文档中对这方面资料较少,记录下 $where['created_time'] = ['$gt' => "$start_date_str ...
随机推荐
- 以环形角度理解php数组索引
array_slice ( array $array , int $offset [, int $length = NULL [, bool $preserve_keys = false ]] ) : ...
- 设置Echarts图例位置
只需要修改如下几个示数即可: ①x:可以选择左(left).右(right).居中(center)②y:可以选择左(left).右(right).居中(center)③padding:[0,30,0, ...
- pyrhon 第一个小购物车例子
product_list=[[],[],[],[]] shopping_list=[] salary = input("请输入你的工资:") if salary.isdigit() ...
- mouseenter 与 mouseover 区别于选择
mouseover事件, 箭头在子元素移动会触发冒泡事件, 子元素的鼠标箭头可触父元素方法, 相反,mouseenter事件功能与mouseover类似, 但鼠标进入某个元素不会冒泡触发父元素方法. ...
- winfrom 集成krpano 项目 添加折线
C#.NET WinFrom开发之嵌入Google浏览器 (CefSharp) 引入静态页面 CefWebBrowser = new ChromiumWebBrowser("http://& ...
- 今天还是python游戏
话不多说,上源码: import random, pygame, sys from pygame.locals import * FPS = 30 # frames per second, the g ...
- 深入分析CAS
CAS,Compare And Swap,即比较并交换.Doug lea大神在同步组件中大量使用CAS技术鬼斧神工地实现了Java多线程的并发操作.整个AQS同步组件.Atomic原子类操作等等都是以 ...
- UI5-技术篇-Expand与Deep 服务测试
1.SEGW创建服务 2.创建Data Model 2.1Entity Types ZRICO_USR 设置主键.排序字段.过滤字段 ZRICO_USRITM设置主键 2.2Associations ...
- python3之面向对象编程理解
面向对象主要有三个特征:封装,继承,多态度. 一.封装 定义类语 class Animal(): class为定义类的关键字,后面跟名字(): python命名规范建议:类一般首字母单词大写,属性变量 ...
- laravel模型关联评论
用户模型 public function show(Post $post,LogManager $log){ $post->load("comments"); //这种方式是 ...