原文地址:伍仪洲的博客

介绍

为什么要进行监控状态,因为在实际的情况中可能会发生一下无法预计的情况,比如阻塞的问题,阻塞的原因会有很多种情况造成,如果当我们查询文档的时候发生了阻塞,那么就会影响到后面的操作,甚至无法对后面的操作进行响应。

我们可以通过监控很快速的找到到底是哪里出了问题,这样有助于我们快速定位所在的问题,从而得到解决。

Mongodb官方提供了三种用语分析Mongodb的方式:

  1. Mongodb自带的监控工具:用于提供数据库活动的实时报告
  2. 数据库命令:以更真实的情况返回数据库状态的统计信息
  3. 第三方平台托管监控

Mongodb自带监控工具

mongostat

mongostat是官方随同mongodb下载包中一同下载的,你可以找到安装目录或者解压目录进行使用。

我们可以通过mongostat --help()进行查询可用选项,也可以通过官方文档进行查询。

Mongostat默认所返回的信息都是基于秒为单位,比如返回的insert指的是每秒插入数据库的对象数,而如果我们限制了返回时间,那么这个返回的结果是基于限制时间的平均值。

-O 和 -o

这两个选项功能非常实用,按照正常的情况,Mongostat输出的报告会有很多我们不需要的列,所以我们可以通过-o来实现,这个选项设置后只会包含我们选择想要列,并且这个选项可以重新命名列的名字,除此之外-o-O还可以添加一些服务器状态到报表中,可以参考ServerStatus

默认的mongostat输出的内容大概如下,并且每秒钟都会返回一个状态:

insert query update delete getmore command flushes mapped vsize   res faults qrw arw net_in net_out conn                time
    *0    *0     *0     *0       0     2|0       0     0B 2.39G 14.0M      0 0|0 0|0   286b   13.8k    1 Aug 24 17:34:17.615
    *0    *0     *0     *0       0     1|0       0     0B 2.39G 14.0M      0 0|0 0|0   285b   13.7k    1 Aug 24 17:34:18.618
    *0    *0     *0     *0       0     2|0       0     0B 2.39G 14.0M      0 0|0 0|0   286b   13.8k    1 Aug 24 17:34:19.617
    *0    *0     *0     *0       0     1|0       0     0B 2.39G 14.0M      0 0|0 0|0   285b   13.8k    1 Aug 24 17:34:20.617

下面的代码选项是重命名了insert列为cr,并只显示insert,query,update:

$ mongostat --host localhost -o 'insert=cr,query,update'

返回后的文档大概如下:
cr query update
*0    *0     *0
*0    *0     *0
*0    *0     *0
*0    *0     *0

-O选项除了输出默认的列之外,可以重命名列名,还可以添加ServerStatus一些字段输出到报表,比如插入文档的总数、主机地址、版本号等信息。

$ mongostat --host localhost -O 'insert=cr,host,version'

返回后的文档大概如下:

cr query update delete getmore command flushes mapped vsize   res faults qrw arw net_in net_out conn                time cr            host version
*0    *0     *0     *0       0     2|0       0     0B 2.39G 14.0M      0 0|0 0|0   286b   13.8k    2 Aug 24 17:51:34.031 *0 localhost:27040   3.4.6
*0    *0     *0     *0       0     1|0       0     0B 2.39G 14.0M      0 0|0 0|0   285b   13.8k    2 Aug 24 17:51:35.032 *0 localhost:27040   3.4.6
*0    *0     *0     *0       0     2|0       0     0B 2.39G 14.0M      0 0|0 0|0   286b   13.8k    2 Aug 24 17:51:36.032 *0 localhost:27040   3.4.6

--rowcount

--rowcount可以控制mongostat返回报表的频率,--rowcount接受的第一个参数为返回的次数,第二个参数是多少秒生成一次报表并返回。

比如我想每五秒返回一次报表,共返回十次:

$ mongostat --rowcount 10 5

--discover

监控副本集或分片的所有成员的统计信息。

mongotop

mongotop可以监控数据库或者副本集的成员中哪个集合最为繁忙。

$ mongotop --host localhost:27030

返回大概如下内容:

                  ns    total    read    write    2017-08-25T20:50:06+08:00
  admin.system.roles      0ms     0ms      0ms
admin.system.version      0ms     0ms      0ms
   local.startup_log      0ms     0ms      0ms
local.system.replset      0ms     0ms      0ms
           test.test      0ms     0ms      0ms

数据库命令

数据库命令可以提供比Mongodb自带的监控工具提供更细微的信息,如果上面的方法无法帮你定位到问题所在,你可以试试下面的数据库命令来操作问题的所在。

db.currentOp

db.currentOp()方法可以列出数据中所有正在进行的所有操作,我们可以通过返回的信息中几个比较重要的字段来找出问题所在。

opid: 操作的ID号,可以通过db.killOp()方法来结束进程,就像系统命令中的PID。

active: 表示该操作当前是否还在运行。

secs_running:这个字段非常重要,我们可以根据此字段判断哪个操作进行了阻塞。

op:操作的类型,比如是查询,可能显示的是query。

desc:表示当前操作在日志中的前缀,我们可以根据此前缀在日志中快速定位。

除此之外,我们还可以过滤参数,得到我们只想要的结果,下面是过滤其他不是当前正在查询的操作。

db.currentOp({op: 'query'});

db.serverStatus

db.serverStatus()方法返回数据库状态的一般概述,详细说明磁盘使用情况,内存使用,连接,日记记录和索引访问。

db.stats db.test.stats rs.status

db.stats()方法返回当前数据库的信息,其中objects就代表的是当前数据库所含的所有文档数量。

db.test.stats()方法返回集合的信息

rs.status()返回当前副本集的信息

参考

MongoDB权威指南(第2版)

Mongodb Docs

Mongodb 监测的更多相关文章

  1. MongoDB创建表步骤,Mongo常用的数据库操作命令,查询,添加,更新,删除_MongoDB 性能监测

    ->use Admin         (切换到创建用户) ->db.TestDb          (创建数据库) ->db.addUser(“userName”,”Pwd”)   ...

  2. MongoDB高可用集群配置的方案

    >>高可用集群的解决方案 高可用性即HA(High Availability)指的是通过尽量缩短因日常维护操作(计划)和突发的系统崩溃(非计划)所导致的停机时间,以提高系统和应用的可用性. ...

  3. MongoDB学习笔记—Linux下搭建MongoDB环境

    1.MongoDB简单说明 a MongoDB是由C++语言编写的一个基于分布式文件存储的开源数据库系统,它的目的在于为WEB应用提供可扩展的高性能数据存储解决方案. b MongoDB是一个介于关系 ...

  4. MongoDB Replica Set 选举过程

    什么是选举? 选举是副本集选择某个成员成为primary的过程.primary是一个副本集中唯一能够接收写操作的成员. 下面的事件能够引发一次选举: 第一次初始化一个副本集 Primary失效.rep ...

  5. mongodb中的副本集搭建实践

    准备运行1个主节点,2个从节点,从节点中其中是一个是仲裁节点(Arb). --oplogSize --oplogSize --oplogSize 其中application是副本集的名称,节点必须相同 ...

  6. MongoDB Replica Set 选举过程

    Replica Set 选举过程 心跳检测 假设我们有三个节点的replica sets:X,Y和Z节点.在replica sets结构中,这三个节点每2秒会各自向其它两个节点发送一个心跳检测请求.比 ...

  7. MongoDB数据访问[C#]附源码下载(查询增删改) 转载

    安装完MongoDBhttp://localhost:28017/监测是否成功! vs 2008 C# MongoDB 源代码下载地址:http://download.csdn.net/source/ ...

  8. mongoDB知识总结

    官方说明文档:https://docs.mongodb.com/manual/mongo/ 1 NoSQL 简介 NoSQL,全称是”Not Only Sql”,指的是非关系型的数据库(相对于关系型数 ...

  9. MongoDB 复制集(二) 选举 自动故障切换

    一   复制集的高可用性简介       复制集通过故障自动切换来实现高可用性,当主节点出现故障的时候,从节点可以通过选举成为主节点,而这个过程在大多数当情况下是自动进行的,不需要手动干预.在某些情况 ...

随机推荐

  1. 百度云bcc建站

    一.购买百度云服务 1.百度云bcc购买网页http://bce.baidu.com/product/bcc.html 2.买完后管理:http://console.bce.baidu.com/bcc ...

  2. C实现dos图文菜单程序实例

      前言 公司一台服务器是novell环境,文件管理是基于dos6.22的,客户端启动需要一个图文菜单.   实现    编程环境:汉化版TC2.0 菜单基本功能:显示提示项.显示dbf中的行情信息. ...

  3. HTML5 drag和drop的亲手实践

    起因 最近在公司打杂的时候,突然分到了一个锅,就是要支持一个新的功能:用户可以通过拖曳组件来改变组件的顺序.因此,这阵子就看了一下网上的一些drag和drog的文章以及W3C的介绍,然后自己亲手实践了 ...

  4. pc端的企业网站(IT修真院test8)详解1-1

    这任务需求我们使用推特的前端框架bootstrap来实现.先放psd图. 上传这些图片也蛮大的.为此我使用office picture manager压缩了图片. 方法:alt+p+o,然后tab+下 ...

  5. 一步一步学Vue(二)

    接上篇,在本篇中,我们将要实现如下,功能,编辑和查询,我们当前的todolist程序,和线上其它的demo程序不同,我们会对其进行增删改查的基本操作,之后进行进一步的完善,按照常规的系统使用经验,一般 ...

  6. iOS开发实战-基于SpriteKit的FlappyBird小游戏

    写在前面 最近一直在忙自己的维P恩的事情 公司项目也是一团乱 于是...随手找了个游戏项目改了改就上线了,就当充数了. SpriteKit简介 SpriteKit是iOS 7之后苹果推出的2D游戏框架 ...

  7. iOS TextView输入长度限制 设置placeholder

    textView在使用中通常会有2个功能是最常用的 设置placeholder 限制输入长度 TYLimitedTextView刚好是为了解决这个2个问题而诞生的,下面讲解TYLimitedTextV ...

  8. 【highchart】经典问题

    摘要 记录遇到的一些问题和解决方案 时差 数据容量 多表联动 1. 时差 问题描述 highcharts 默认是标准 UTC 时间,而国内默认是东八区时间,所以会有8个小时的时差 解决方法 使用hig ...

  9. 共享---samba

    1.  虚拟机,可以采用共享文件夹 2.  windows之间可以使用网络邻居共享 3.  windows与linux,linux与linux之间建立samba服务器 4.  安装samba服务器 r ...

  10. 给ubuntu的swap分区增加容量

    1.创建一个 Swap 文件. mkdir swap cd swap sudo dd if=/dev/zero of=swapfile bs=1024 count=100000 出现下列提示,上面命令 ...