shell下的查看当前Mongodb运行状态的两个重要命令(db.stats()&&db.db.serverStatus())

db.stats()

《shell下的查看当前Mongodb运行状态的两个重要命令(db.stats()&&db.db.serverStatus())》 示例图

参数解释:

“db” : “test” ,表示当前是针对”test”这个数据库的描述。想要查看其他数据库,可以先运行$ use databasename(e.g $use admiin).

“collections” : 3,表示当前数据库有多少个collections.可以通过运行show collections查看当前数据库具体有哪些collection.

“objects” : 13,表示当前数据库所有collection总共有多少行数据。显示的数据是一个估计值,并不是非常精确。

“avgObjSize” : 36,表示每行数据是大小,也是估计值,单位是bytes

“dataSize” : 468,表示当前数据库所有数据的总大小,不是指占有磁盘大小。单位是bytes

“storageSize” : 13312,表示当前数据库占有磁盘大小,单位是bytes,因为mongodb有预分配空间机制,为了防止当有大量数据插入时对磁盘的压力,因此会事先多分配磁盘空间。

“numExtents” : 3,似乎没有什么真实意义。我弄明白之后再详细补充说明。

“indexes” : 1 ,表示system.indexes表数据行数。

“indexSize” : 8192,表示索引占有磁盘大小。单位是bytes

“fileSize” : 201326592,表示当前数据库预分配的文件大小,例如test.0,test.1,不包括test.ns。

db.serverStatus()

参数太多,示例图略

参数解释

FieldExample ValueExplanation
Hostte.rzw.com:27018运行实例所监听的IP与端口
version1.8.3当前实例所使用的版本
Processmongod当前实例是mongod,还是mongos
Uptime231905实例连续正常运行时间,单位秒
uptimeEstimate223083基于mongodb内部粗粒定时器的连续正常运行时间
localTimeISODate(“2011-10-13T01:47:38.773Z”)本机时间,以UTC时间为计算标准。
globalLock.totalTime231905155987自实例启动全局锁创建以来到现在多长时间,单位微秒.
globalLock.lockTime9053050自全局锁创建以来锁定总时间,单位微秒
globalLock.ratio0.0000390377262锁定的时间所占的比例(lockTime/ totalTime)
globalLock.currentQueue.total0当前等待全局锁的数量
globalLock.currentQueue.readers0当前等待读锁的数量
globalLock.currentQueue.writers0当前等待写锁的数量
globalLock.activeClients.total1连接到当前实例处于活动状态的客户端数量。
globalLock.activeClients.readers1处于活动状态的客户端中有多少是在执行read操作
globalLock.activeClients.writers0处于活动状态的客户端中有多少是在执行write操作
Mem.resident6到现在总共使用的物理内存,单位是MB
Mem.virtual17307当前Mongodb实例使用的虚拟内存大小,单位MB,一般情况下比mem.map的值要超大一点,如果大很多很有可能发生内存泄露,如果使用journal,大约是2倍的map值
Mem.maped8556Mongodb使所有数据都映射到内存中,所以这个值可以看似整个数据量的值。
Mem.bits64机器位数,32位或64位
Mem.supportedtrue本机是否支持内存扩展
Connections.current2当前连接到本机处于活动状态的连接数
Connections. available19998剩余多少可供连接
extra_info. heap_usage_bytes521152当前实例堆大小,单位bytes
extra_info. page_faults569加载磁盘内容时发生页错误的次数
indexCounters. Btree.accesses1访问索引次数
indexCounters. Btree.hits1访问索引时,索引在内存中被命中的次数
indexCounters. Btree.misses0访问索引时,索引不是在内存中被命中的次数
indexCounters. Btree.resets0索引计数器被重置的次数
indexCounters. Btree.missRatio0索引非命中率
backgroundFlushing.flushes3864实例刷新数据到磁盘的数次
backgroundFlushing.total_ms15473刷新到磁盘总共花费的时间,单位毫秒
backgroundFlushing.average_ms4.004399585921325平均每次刷新执行时间
backgroundFlushing.last_ms3最后一次刷新执行时间
backgroundFlushing.last_finishedISODate(“2011-10-13T01:46:51.184Z”)最后一次刷新完成的时间点
Cursors.totalOpen1当前游标数量
Cursors.timeOut2从实例启动到现在游标超时的总数量
Network.bytesIn4680778发送到实例的字节大小
Network.bytesOut4759827发送出去的字节大小
Repl.setNamemysetreplSet结构定义的名称
Repl.isMasterTrue当前实例是否是replSet结构中的Master节点
Repl.secondaryFalse当前实例是否是replSet结构中的secondary节点
Repl.hosts[ “te.rzw.com:27018”,”te.rzw.com:27019”]replSet结构中每个节点情况
Opcounters.insert4自实例启动以来,执行insert次数
Opcounters.query181自实例启动以来,执行query次数
Opcounters.update92084自实例启动以来,执行update次数
Opcounters.delete0自实例启动以来,执行delete次数
Opcounters.getmore92816自实例启动以来,在游标执行getMore次数
Opcounters.command316自实例启动以来,执行其他操作的次数
Asserts.regular0自实例启动以来,断言正常的次数
Asserts.warn0自实例启动以来,断言警告的次数
Asserts.msg0自实例启动以来,断言内部错误的次数
Asserts.user134自实例启动以来,因用户使用造成的错误而被断言次数
Asserts.rollovers0断言被翻转的次数
writeBacksQueuedFalse在mongos中,操作被重做的次数
Dur.commits1在最近间隔,向journal文件提交的次数
Dur.journaledMB0.008192在最近间隔,journalr文件写入数据量,单位MB
Dur. writeToDataFilesMB0在最近间隔,从journal文件向数据文件写入的数据量,单位MB
Dur. commitsInWriteLock0在最近间隔中,处于写锁状态下向journal提交的次数.这种提交方式是不被推荐的
Dur.earlyCommits0在预定时间之前请求提交的次数
Dur.timeMs.dt3045Journal状态收集的频率,单位毫秒
Dur.timeMs. prepLogBuffer0向journal写数据前的准备所花费时间, 单位毫秒
Dur.timeMs. writeToJournal2向journal写数据所花费时间,单位毫秒
Dur.timeMs. writeToDataFiles0在写入journal文件后向数据文件写数据花费时间,单位毫秒
Dur.timeMs. remapPrivateView0重新在内存中映射数据花费的时间
Ok1serverStatus操作是否被成功执行

备注:文章原文摘自: 雪刚

    原文作者:水车306
    原文地址: https://www.jianshu.com/p/da43f0234d47
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞