mongodb监控常用方法

列举mongodb监控的常用命令

1.监控统计

mongostat 可用于查看当前QPS/内存使用/连接数,以及多个shard的压力分布

命令参考

./mongostat --port 27071  -u admin -p xxx --authenticationDatabase=admin --discover -n 30 3

参数说明
-discover 提供集群中所有节点的状态
-n 30 3 表示输出30次,每次休眠3秒钟

输出示例

                   insert query update delete getmore command  %dirty  %used flushes mapped vsize   res faults qr|qw  ar|aw netIn netOut conn    set repl                      time
185.1.12.101:10001    499  4886   2042   1612     237   756|0     3.8   80.1       0        28.5G 19.1G    n/a   3|0    1|1    4m     7m 5545 shard0  PRI 2017-03-06T11:48:17+08:00

指标说明

指标名 说明
inserts/s 每秒插入数
query/s 每秒查询数
update/s 每秒更新数
delete/s 每秒删除数
getmore/s 每秒getmore数
command/s 每秒命令数,涵盖了增删改查和其他操作
dirty/% WriedTiger引擎参数,缓存中无效数据百分比
used/% WriedTiger引擎参数,正在使用的缓存百分比
flushs/s 每秒执行fsync将数据写入硬盘次数
mapped/MB 所有的被mmap的数据量
vsize/MB 虚拟内存使用量
res/MB 物理内存使用量
faults/s 每秒访问失败数,与内存swap有关
qrqw 客户端读写等待队列数量,高并发时,一般队列值会升高
araw 客户端读写活跃个数
netIn 网络接收数据量
netOut 网络发送数据量
conn 当前连接数
set 所属集合(分片)
repl 复制状态(主节点/二级节点..)
time 时间戳

官方说明
https://docs.mongodb.com/manual/reference/program/mongostat/

2.热点操作

mongotop 用于查看当前占用比例较高的DB操作,即热点操作。

命令参考

./mongotop --port 10001  -u admin -p xxx --authenticationDatabase=admin

输出示例

    ns                  total   read    write   2017-03-20T15:22:36+08:00
    nscl.T_De**ata      407ms   266ms   140ms
    nscl.T_OAUT**EN     251ms   242ms   8ms
    nscl.T_Subs**tion   180ms   180ms   0ms
    nscl.T_De**istory   61ms    0ms     61ms                             

官方说明
https://docs.mongodb.com/manual/reference/program/mongotop/

3.慢操作检测

profile是mongodb实现慢操作检测的模块,官方说明

连接shell(使用root)

./mongo --port 10001  -u root -p xxx --authenticationDatabase=admin
use admin

注意
profile操作必须连接mongod进程,而mongos无法执行此类操作

profile设置

db.setProfilingLevel(0) 不输出慢查询
db.setProfilingLevel(1,100) 统计慢查询,100ms是阈值
db.setProfilingLevel(2) 统计所有操作
db.getProfilingLevel()

查询慢查询

db.system.profile.find().limit(10).sort( { ts : -1 } ).pretty()
db.system.profile.find().limit(10).sort( { millis : -1 } ).pretty()

查询当前操作

db.currentOp()
  • 样例-查询等待锁的增删改查

    db.currentOp(
       {
     "waitingForLock" : true,
     $or: [
        { "op" : { "$in" : [ "insert", "update", "remove" ] } },
        { "query.findandmodify": { $exists: true } }
    ]
       }
    )
  • 样例-查询活跃query操作
    db.currentOp(true).inprog.forEach(
       function(opDoc){
     if(!opDoc.active && opDoc.op=='query')
        printjson(d)
     }
     )

    currentOp更多说明

4. 集合状态分析

数据库状态

db.stats()
->
{
  "db" : "test",           //当前数据库
  "collections" : 3,       //集合数量
  "objects" : 165606718,   //对象数量
  "avgObjSize" : 381,      //对象平均大小
  "dataSize" : 63142130610, //所有数据总大小
  "storageSize" : 16384,    //数据占磁盘大小
  "numExtents" : 3,
  "indexes" : 479,          //索引数
  "indexSize" : 8011636736, //索引大小
  "fileSize" : 201326592    //预分配给数据库的文件大小
} 

集合状态

db.xxx.stats()
->
   ...
    "sharded" : true,      //是否分片
    "capped" : false,      //是否限制大小
    "ns" : "nscl.T_BUSINESS_LOG",
    "count" : 26541837,         //表数量
    "size" : 14991828070,       //表大小
    "storageSize" : 3615076352, //占磁盘大小
    "totalIndexSize" : 2640109568, //索引大小
    "avgObjSize" : 564.8376210734773,
    "nindexes" : 6,
    "nchunks" : 374         //chunk数量
   ...

原文地址:https://www.cnblogs.com/littleatp/p/8419647.html

时间: 2024-10-14 19:40:27

mongodb监控常用方法的相关文章

Mongodb监控命令

Mongodb监控命令 一.监控工具 1.mongostat工具 默认为显示每秒的统计信息 # mongostat -uroot -ppassword --authenticationDatabase admin -h192.168.x.xx  --rowcount 10 1 connected to: 192.168.x.xx insert  query update delete getmore command flushes mapped  vsize    res faults  loc

Mongodb监控

Mongodb监控主要利用的是其自带的rest服务,默认端口是27017+1000,后接serverStatus. Mongodb需要开启rest服务才能进行监控.其中,2.2版本一下会自动启动rest服务,2.2-2.6之间需要通过如下命令启动rest服务: mongod –dbpath ************ --rest     而2.6以上需要改动mongod.conf文件,将OPTIONS加入 –rest –httpinterface { "host" : "ac

PCB MongoDB 监控

一个数据库监控工具是必不可少的,当然MongoDB安装自带监控啦. 这里将监控工具mongostat.exe与mongotop.exe使用与参数进行讲解说明. 一.监控工具说明: 二.监控工具启用 1.进行MongoDB安装目录: cd D:\Program Files\MongoDB\Server\4.0\bin 2.启动  mongostat 1     1为监控时间间隔为1秒(默认也是1秒) mongostat 1 下图为监控间隔10秒 三.mongostat 监控参数说明: 监控增删改查

mongodb 监控项详解(mms)

mongodb mms监控项 Opcounters :     当前有执行命令的操作(command,query,update,delete,gemore,insert)次数 Connections :      当前与此服务器的活动连接的数量.每个连接分配一个堆栈;因此,非常多的连接会导致严重的RAM使用 page_faults :        页面错误的平均利率这一过程在选定的样本期间每秒 Memory :            驻留,虚拟,映射内存的大小 Network :      

Zabbix MongoDB监控

去年监控mongodb设置的模板,包括mongodb连接数,内存,复制延迟,是否Master的监控,下面是一些监控图形示例 我们还有一些触发器,比如mongodb实例是否可用,mongodb副本集的角色是否切换. 附件中是mongodb的模板文件,后台的脚本改日再行上传.

MongoDB 监控

在你已经安装部署并允许MongoDB服务后,你必须要了解MongoDB的运行情况,并查看MongoDB的性能.这样在大流量得情况下可以很好的应对并保证MongoDB正常运作. MongoDB中提供了mongostat 和 mongotop 两个命令来监控MongoDB的运行情况. mongostat 命令 mongostat是mongodb自带的状态检测工具,在命令行下使用.它会间隔固定时间获取mongodb的当前运行状态,并输出.如果你发现数据库突然变慢或者有其他问题的话,你第一手的操作就考虑

MongoDB监控三 MongoDB自带监控方法

REST接口 MongoDB提供一个简单的REST接口可用于配置监控和告警脚本和其他一些管理任务. 可以通过在命令行添加 --rest参数或在配置文件加上rest=true开启REST接口支持. 具体可以参见文档http://docs.mongodb.org/ecosystem/tools/http-interfaces/ HTTP接口 MongoDB提供一个简单的HTTP接口,如当前MongoDB实例运行的端口是28018,那么可以通过http://127.0.0.1:38018 访问 具体可

MongoDB负载信息一目了然 阿里云HDM重磅发布MongoDB监控和诊断功能

混合云数据库管理(HDM)的统一监控.告警.诊断功能新增了对MongoDB的支持. 通过直观的方式将MongoDB多个维度的负载信息统一整合,不仅可以清晰的查看实时负载信息,也可以方便的确认历史负载情况,同时也支持自定义性能监控大盘. 通过该功能,专业的DBA可以减少信息收集和处理的事件,提升效率,非专业人士也能快速检测问题. 典型使用场景 直观地确认数据库负载情况 数据库诊断和优化过程具有相当的复杂性.专业性,其中: 1.数据库负载相关信息的获取,需要依赖于大量的主机性能数据.引擎运行数据库(

mongodb监控脚本

脚本涵盖两种监控mongo的方法:使用自带的mongostat工具查看,各个监控项的位置可能要按实际的mongostat输出进行调整:进入admin库,查看具体状态信息,可能需要验证. 完整步骤: 1.创建用于监控的用户角色:mongo用户的权限按用户角色进行划分 > use admin  > db.getRoles() > db.createRole(     { role:"mongostatRole",      privileges:[{resource:{c