MongoDB监控四 dbStats和collStats和replSetGetStatus

  1. dbStats命令

    dbStats命令可以返回指定数据库的存储信息,默认是以bytes为单位显示存储信息,可以增加一个scale参数,如scale : 1024表示kilobytes显示。返回信息的时间由指定数据库的大小决定。

> db.runCommand({dbStats : 1,scale : 1})
{
	"db" : "test",
	"collections" : 28,
	"objects" : 161,
	"avgObjSize" : 61.391304347826086,
	"dataSize" : 9884,
	"storageSize" : 245760,
	"numExtents" : 29,
	"indexes" : 67,
	"indexSize" : 547792,
	"fileSize" : 201326592,
	"nsSizeMB" : 16,
	"dataFileVersion" : {
		"major" : 4,
		"minor" : 5
	},
	"ok" : 1
}
> db.runCommand({dbStats : 1,scale : 1024})
{
	"db" : "test",
	"collections" : 28,
	"objects" : 161,
	"avgObjSize" : 61.391304347826086,
	"dataSize" : 9,
	"storageSize" : 240,
	"numExtents" : 29,
	"indexes" : 67,
	"indexSize" : 534,
	"fileSize" : 196608,
	"nsSizeMB" : 16,
	"dataFileVersion" : {
		"major" : 4,
		"minor" : 5
	},
	"ok" : 1
}

   也可以使用db.stats()或者db.stats(1024)

> db.stats(1024)
{
	"db" : "test",
	"collections" : 28,
	"objects" : 161,
	"avgObjSize" : 61.391304347826086,
	"dataSize" : 9,
	"storageSize" : 240,
	"numExtents" : 29,
	"indexes" : 67,
	"indexSize" : 534,
	"fileSize" : 196608,
	"nsSizeMB" : 16,
	"dataFileVersion" : {
		"major" : 4,
		"minor" : 5
	},
	"ok" : 1
}

   db  当前数据库的名称,如果要查看指定数据库的存储信息,可以使用use test

   collections     当前数据库中包含的集合数量

   objects         数据库中所有集合包含的对象(例如文档)数量

   avgObjSize      每个文档的平均大小,用byte表示,这个值等于dataSize除以objects

   dataSzie        当前数据库持有的数据大小,包括padding factor, scale会影响这个值,当文档的大小缩小时,dataSzie不会减小,但是如果删除文档,dataSize的值会减小

   storageSize     分配给该数据库用于存储所有集合的文档的存储空间大小,以bytes计算,scale会影响这个值,当删除或缩小文档时,storageSize的值不会减小

   numExtents      数据库中所有集合包含的extent数量

   indexes         数据库中所有集合包含的索引数量

   indexSize       在这个数据库上创建的所有索引的大小,以bytes表示,scale会影响这个值

   fileSize        数据库的数据文件的大小,以bytes表示,这个值包括预分配空间和padding factor,这个值只能反映数据文件的大小,不能反映域名空间的大小,sacle的值会影响这个值

   nsSizeMB        以.ns结尾的文件的大小,默认情况下是16MB,可以在配置文件设置nssize的值,或启动mongod进程时,增加--nssize 参数。

   dataFileVersion  数据库相关的数据文件的磁盘格式信息


2.collStats命令

  collStats命令或者db.collection.Stats()可以查看单个集合的存储信息,collection是指定的集合,如player集合就可以写成db.player.Stats(),scale用来指定显示的数据单位

> use zhanguo_server_jd01;
switched to db zhanguo_server_jd01
jidong:PRIMARY> db.runCommand({collStats : 'player',scale : 1024})
{
	"ns" : "zhanguo_server_jd01.player",    
	"count" : 93263,                        
	"size" : 94040,
	"avgObjSize" : 1.008331278213225,
	"storageSize" : 106988,
	"numExtents" : 8,
	"nindexes" : 4,
	"lastExtentSize" : 37796,
	"paddingFactor" : 1.000000000001303,
	"systemFlags" : 1,
	"userFlags" : 0,
	"totalIndexSize" : 20607,
	"indexSizes" : {
		"_id_" : 3113,
		"uid_1" : 8543,
		"user_name_1" : 4032,
		"email_1" : 4918
	},
	"ok" : 1
}
jidong:PRIMARY> db.player.stats(1024)
{
	"ns" : "zhanguo_server_jd01.player",
	"count" : 93263,
	"size" : 94040,
	"avgObjSize" : 1.008331278213225,
	"storageSize" : 106988,
	"numExtents" : 8,
	"nindexes" : 4,
	"lastExtentSize" : 37796,
	"paddingFactor" : 1.000000000001303,
	"systemFlags" : 1,
	"userFlags" : 0,
	"totalIndexSize" : 20607,
	"indexSizes" : {
		"_id_" : 3113,
		"uid_1" : 8543,
		"user_name_1" : 4032,
		"email_1" : 4918
	},
	"ok" : 1
}


   ns            域名空间,由数据库名和集合名构成

   count         集合中包含的文档数量

   size          集合中所有记录的总大小,这里的值不包括record head,每个record head是16个字节,但是不包括record's padding.也不包括所有索引的大小,索引的大小由totalIndexSize的值决定,scale也会影响这个值

   avgObjSize    集合中一个对象的平均大小。scale的值会影响这个值

   storageSize   分配给集合存储所有文档的存储空间,scale的值会影响这个值,移除或缩小文档,存储空间不会减小

   numExtents    The total number of contiguously allocated data file regions.

     nindexes            这个集合的索引数量,所有集合至少在_id字段有个索引

     lastExtentSize    最后一个extent分配的大小,scale会影响这个值

     paddingFactor    在插入时间时,在每个文档末尾增加的总空间大小,通过为每个文档在磁盘上分配额外的空间,可以使用每个文档小幅增长时不需要移动文档。

   systemFlags    通常值为1

   userFlags      

   totalIndexSize   索引的总大小,scale会影响这个值

   indexSizes     分开显示每个索引的大小,scale会影响这个值


3.replSetGetStatus 命令

  使用replSetGetStatus命令可以反映复制集的状态,使用这个命令需要在admin数据库下使用。

  同时在mongo终端下使用rs.status()也可以显示相同的信息

  

  

  set                   复制集的名称

  date                  当前时间,可以和lastHeartbeat的值对比当前主机和复制集中的其他主机的操作延迟时间

  myState               当前主机在复制集中的编号

  members               集合每个成员的信息

             name       成员名称,主机名(IP)+端口

             self       当前mongod实例才会有这个字段

             health     是否健康

             stateStr   在复制集中的状态,是PRIMARY,SECONDARY还是ARBITER

             uptime     在线时间,以秒为单位

             optime     Information regarding the last operation from the operation log that this member has applied.

                       optimeDate          An ISODate formatted date string that reflects the last entry from   the oplog that this member applied. 

                       lastHeartbeat        The lastHeartbeat value provides an ISODate formatted date and time of the transmission time of last heartbeat received from this member. 

             lastHeartbeatRecv  The lastHeartbeat value provides an ISODate formatted date and time that the last heartbeat was received from this member.

             pingMs     以毫秒表示当前实例到远程实例的发送往返包的时间

             syncingTo  指定要同步的mongod,即Primary

             


jidong:SECONDARY> use admin
switched to db admin
jidong:SECONDARY> db.runCommand({replSetGetStatus : 1})
{
	"set" : "jidong",
	"date" : ISODate("2014-10-20T01:36:46Z"),
	"myState" : 2,
	"syncingTo" : "zg-jidong-mgbackup:28018",
	"members" : [
		{
			"_id" : 0,
			"name" : "zg-jidong-mongodb:28018",
			"health" : 1,
			"state" : 2,
			"stateStr" : "SECONDARY",
			"uptime" : 5764907,
			"optime" : Timestamp(1413769005, 19),
			"optimeDate" : ISODate("2014-10-20T01:36:45Z"),
			"self" : true
		},
		{
			"_id" : 1,
			"name" : "zg-mongodb-arbiter:28018",
			"health" : 1,
			"state" : 7,
			"stateStr" : "ARBITER",
			"uptime" : 5764874,
			"lastHeartbeat" : ISODate("2014-10-20T01:36:45Z"),
			"lastHeartbeatRecv" : ISODate("2014-10-20T01:36:46Z"),
			"pingMs" : 0
		},
		{
			"_id" : 2,
			"name" : "zg-jidong-mgbackup:28018",
			"health" : 1,
			"state" : 1,
			"stateStr" : "PRIMARY",
			"uptime" : 5764874,
			"optime" : Timestamp(1413769005, 10),
			"optimeDate" : ISODate("2014-10-20T01:36:45Z"),
			"lastHeartbeat" : ISODate("2014-10-20T01:36:46Z"),
			"lastHeartbeatRecv" : ISODate("2014-10-20T01:36:45Z"),
			"pingMs" : 0
		}
	],
	"ok" : 1
}

     

你可能感兴趣的:(监控,dbStats)