监控 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
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


  • 2020-01-30 11:19:58

    Android中添加两个(多个)FileProvider节点问题

    我们知道在android7.0,修改了对私有存储的限制,导致在获取资源的时候,不能通过Uri.fromFile(..)来获取uri了,但是在写入数据的时候是可以通过Uri.fromFile(..)来获取uri的,android 官网给出的解决办法是通过FileProvider来解决这一问题,我们需要在AndroidManifest.xml 配制provider节点。

  • 2020-02-02 15:40:36

    Apache Commons IO之IOUtils优雅操作流

    在开发过程中,你肯定遇到过从流中解析数据,或者把数据写入流中,或者输入流转换为输出流,而且最后还要进行流的关闭,原始jdk自带的方法写起来太复杂,还要注意各种异常,如果你为此感到烦恼,那IOUtils可以让我们优雅的操作流。

  • 2020-02-02 19:24:38

    百度视频SDK,突然不能播放

    开发过程中,不知道什么时候开始视频不能播发了,怎么办都不行,其他项目没问题,线上都也没有问题,这可急躁完蛋我了,整了仨小时,还是那熊样。 哎。

  • 2020-02-04 18:43:10

    AssetManager.finalize() Timed Out 解决办法以及分析

    在我们的项目崩溃中,有一个比较常见的bug,就是 java.util.concurrent.TimeoutException android.content.res.AssetManager.finalize() timed out after 10 seconds 意思简单明了,就是说在AssetManager析构的时候发生了超时异常。