监控 MongoDB -

2021-01-15 13:06:08

参考地址 MongoDB - 监控

随着MongoDB中保存的数据越来越多,对MongoDB服务状态的监控也越来越重要,经常关注服务是否健康,才能防止故障以及优化。

1.静态监控db.serverStatus()

使用mongo命令进入shell客户端后输入以下命令可以查看MongoDB服务的状态,有助于故障诊断和性能分析。

db.serverStatus()

此命令的输出信息非常多,看得眼花缭乱,可以根据实际情况有选择地查询监控信息。

  • 主机名

db.serverStatus().host

db.serverStatus().locks
  • 全局锁

db.serverStatus().globalLock
  • 内存

db.serverStatus().mem
  • 连接数

db.serverStatus().connections
  • 额外信息

db.serverStatus().extra_info
  • 索引统计

db.serverStatus().indexCounters
  • 后台刷新

db.serverStatus().backgroundFlushing
  • 游标

db.serverStatus().cursors
  • 网络

db.serverStatus().network
  • 副本集

db.serverStatus().repl
  • 副本集操作计数器

db.serverStatus().opcountersRepl
  • 操作计数器

db.serverStatus().opcounters
  • 断言

db.serverStatus().asserts
  • 回写队列

db.serverStatus().writeBacksQueued
  • 持久化

db.serverStatus().dur
  • 记录状态

db.serverStatus().recordStats
  • 工作集

 db.serverStatus({workingSet:1}).workingSet
  • 指标

db.serverStatus().metrics

2.动态监控mongostat

MongoDB还提供了动态的监控工具mongostat,mongostat会每秒输出一次serverStatus提供的重要信息。(有点类似Linux系统上的top工具)。

$ mongostat
insert query update delete getmore command % dirty % used flushes vsize   res qr|qw ar|aw netIn netOut conn                      time
    *0    *0     *0     *0       0     1|0     0.0    0.0       0  316M 58.0M   0|0   0|0   79b  21.1k    1 2018-05-21T17:03:55+08:00
    *0    *0     *0     *0       0     1|0     0.0    0.0       0  316M 58.0M   0|0   0|0   79b  21.1k    1 2018-05-21T17:03:56+08:00
    *0    *0     *0     *0       0     1|0     0.0    0.0       0  316M 58.0M   0|0   0|0   79b  21.1k    1 2018-05-21T17:03:57+08:00
    *0    *0     *0     *0       0     1|0     0.0    0.0       0  316M 58.0M   0|0   0|0   79b  21.1k    1 2018-05-21T17:03:58+08:00
    *0    *0     *0     *0       0     1|0     0.0    0.0       0  316M 58.0M   0|0   0|0   79b  21.1k    1 2018-05-21T17:03:59+08:00
    *0    *0     *0     *0       0     1|0     0.0    0.0       0  316M 58.0M   0|0   0|0   79b  21.1k    1 2018-05-21T17:04:00+08:00

3.第三方工具

除了上述方法可以对MongoDB进行监控,还有一些第三方的工具,如:Hyperic、Zabbix、OpenFalcon等,可以根据实际需要选择。



作者:yuanzicheng
链接:https://www.jianshu.com/p/3aee695037bc
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


  • 2017-06-17 18:33:17

    NodeJs使用asyncAwait两法

    async/await使用同步的方式来书写异步代码,将异步调用的难度降低到接近于0,未来必将大放异彩。然而在当下,由于标准化的缓存步伐,async/await尚在ES7的草案中。为了尝先,特试用了下面两种方式:

  • 2017-06-18 02:26:17

    Incorrect string value: '\xF0\x9F\x98\x84\xF0\x9F

    我们可以看到错误提示中的字符0xF0 0x9F 0x98 0x84 ,这对应UTF-8编码格式中的4字节编码(UTF-8编码规范)。正常的汉字一般不会超过3个字节,为什么为出现4个字节呢?实际上是它对应的是智能手机输入法中的表情。那为什么会报错呢?

  • 2017-06-18 02:34:22

    谈mysql中utf8和utf8mb4区别

    MySQL在5.5.3之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode。好在utf8mb4是utf8的超集,除了将编码改为utf8mb4外不需要做其他转换。当然,为了节省空间,一般情况下使用utf8也就够了。

  • 2017-07-05 09:48:51

    CSS 元素垂直居中的 6种方法

    利用CSS进行元素的水平居中,比较简单,行级元素设置其父元素的text-align center,块级元素设置其本身的left 和 right margins为auto即可。本文收集了六种利用css进行元素的垂直居中的方法,每一种适用于不同的情况,在实际的使用过程中选择某一种方法即可。

  • 2017-07-06 10:02:18

    大白话讲解Promise(一)

    去年6月份, ES2015正式发布(也就是ES6,ES6是它的乳名),其中Promise被列为正式规范。作为ES6中最重要的特性之一,我们有必要掌握并理解透彻。本文将由浅到深,讲解Promise的基本概念与使用方法。

  • 2017-07-11 21:54:14

    MYSQL5.7版本sql_mode=only_full_group_by问题

    一旦开启 only_full_group_by ,感觉,group by 将变成和 distinct 一样,只能获取受到其影响的字段信息,无法和其他未受其影响的字段共存,这样,group by 的功能将变得十分狭窄了