db.collection.stats()

On this page本页内容

Definition定义

db.collection.stats(<option>)

mongo Shell Method

This page documents the mongo shell method, and does not refer to the MongoDB Node.js driver (or any other driver) method. 本页记录了mongo shell方法,未提及MongoDB Node.js驱动程序(或任何其他驱动程序)方法。For corresponding MongoDB driver API, refer to your specific MongoDB driver documentation instead.有关相应的MongoDB驱动程序API,请参阅特定的MongoDB驱动程序文档。

Returns statistics about the collection.返回有关集合的统计信息。

The method has the following format:该方法具有以下格式:

db.collection.stats({
   scale: <num>,                   // Optional
   indexDetails: <boolean>,        // Optional
   indexDetailsKey: <document>,    // Optional
   indexDetailsName: <string>.     // Optional
})
Field字段Type类型Description描述
scale number

Optional.可选。The scale factor for the various size data. 各种大小数据的比例因子。The scale defaults to 1 to return size data in bytes. scale默认为1,以字节为单位返回大小数据。To display kilobytes rather than bytes, specify a scale value of 1024.要显示千字节而不是字节,请指定1024scale值。

If you specify a non-integer scale factor, MongoDB uses the integer part of the specified factor. 如果指定非整数比例因子,MongoDB将使用指定因子的整数部分。For example, if you specify a scale factor of 1023.999, MongoDB uses 1023 as the scale factor.例如,如果指定比例因子1023.999,MongoDB将使用1023作为比例因子。

Starting in version 4.2, the output includes the scaleFactor used to scale the size values.从4.2版开始,输出包括用于缩放大小值的scaleFactor

indexDetails boolean

Optional.可选。If true, db.collection.stats() returns index details in addition to the collection stats.如果为true,则db.collection.stats()除了返回集合统计信息外,还返回索引详细信息

Only works for WiredTiger storage engine.仅适用于WiredTiger存储引擎。

Defaults to false.默认为false

indexDetailsKey document

Optional.可选。If indexDetails is true, you can use indexDetailsKey to filter index details by specifying the index key specification. 如果indexDetailstrue,则可以使用indexDetailsKey通过指定索引键规范来筛选索引详细信息。Only the index that exactly matches indexDetailsKey will be returned.只返回与indexDetailsKey完全匹配的索引。

If no match is found, indexDetails will display statistics for all indexes.如果没有找到匹配项,indexDetails将显示所有索引的统计信息。

Use getIndexes() to discover index keys. 使用getIndexes()来发现索引键。You cannot use indexDetailsKey with indexDetailsName.不能将indexDetailsNameindexDetailsName一起使用。

indexDetailsName string

Optional.可选。If indexDetails is true, you can use indexDetailsName to filter index details by specifying the index name. 如果indexDetailstrue,则可以使用indexDetailsName通过指定索引名称来筛选索引详细信息。Only the index name that exactly matches indexDetailsName will be returned.只返回与indexDetailsName完全匹配的索引名。

If no match is found, indexDetails will display statistics for all indexes.如果没有找到匹配项,indexDetails将显示所有索引的统计信息。

Use getIndexes() to discover index names. 使用getIndexes()查找索引名。You cannot use indexDetailsName with indexDetailsField.不能将indexDetailsNameindexDetailsField一起使用。

To specify just the scale factor, MongoDB supports the legacy format:为了只指定scale因子,MongoDB支持传统格式:

db.collection.stats(<number>)
Returns:返回:A document that contains statistics on the specified collection. 包含指定集合统计信息的文档See collStats for a breakdown of the returned statistics.请参阅collStats以获取返回的统计数据的细分。

The db.collection.stats() method provides a wrapper around the database command collStats.db.collection.stats()方法为数据库命令collStats提供了一个包装器。

Behavior行为

Scaled Sizes按比例大小

Unless otherwise specified by the metric name (such as "bytes currently in the cache"), values related to size are displayed in bytes and can be overridden by scale.除非度量名称(例如“缓存中当前的字节”)另有规定,否则与大小相关的值以字节为单位显示,并且可以按比例覆盖。

The scale factor rounds the affected size values to whole numbers.比例因子将受影响的大小值舍入为整数。

Storage Engine存储引擎

Depending on the storage engine, the data returned may differ. 根据存储引擎的不同,返回的数据可能会有所不同。For details on the fields, see output details.有关字段的详细信息,请参阅输出详细信息

Accuracy after Unexpected Shutdown意外停机后的精度

After an unclean shutdown of a mongod using the Wired Tiger storage engine, count and size statistics reported by db.collection.stats() may be inaccurate.在使用Wired Tiger存储引擎不干净地关闭mongod后,db.collection.stats()报告的计数和大小统计数据可能不准确。

The amount of drift depends on the number of insert, update, or delete operations performed between the last checkpoint and the unclean shutdown. 漂移量取决于在最后一个检查点和不干净关机之间执行的插入、更新或删除操作的数量。Checkpoints usually occur every 60 seconds. 检查点通常每60秒出现一次。However, mongod instances running with non-default --syncdelay settings may have more or less frequent checkpoints.但是,使用非默认的--syncdelay设置运行的mongod实例可能有更多或更少的检查点。

Run validate on each collection on the mongod to restore the correct statistics after an unclean shutdown.mongod上的每个集合上运行validate,以在不干净的关闭后恢复正确的统计数据。

Replica Set Member State Restriction副本集成员状态限制

Starting in MongoDB 4.4, to run on a replica set member, collStats operations require the member to be in PRIMARY or SECONDARY state. 从MongoDB 4.4开始,要在副本集成员上运行,collStats操作要求该成员处于PRIMARYSECONDARY状态。If the member is in another state, such as STARTUP2, the operation errors.如果成员处于另一种状态,例如STARTUP2,则操作会出错。

In previous versions, the operations can also be run when the member is in STARTUP2. 在以前的版本中,当成员在STARTUP2中时,也可以运行这些操作。However, the operations wait until the member transitions to RECOVERING.但是,这些操作将等待成员转换到RECOVERING

Index Filter Behavior索引筛选器行为

Filtering on indexDetails using either indexDetailsKey or indexDetailsName will only return a single matching index. 使用indexDetailsKey或indexDetailsNameindexDetails进行筛选将只返回一个匹配的索引。If no exact match is found, indexDetails will show information on all indexes for the collection.如果没有找到精确匹配,indexDetails将显示集合的所有索引的信息。

The indexDetailsKey field takes a document of the following form:indexDetailsKey字段采用以下格式的文档:

{ '<string>' : <value>, '<string>' : <value>, ... }

Where <string>> is the field that is indexed and <value> is either the direction of the index, or the special index type such as text or 2dsphere. 其中,<string>>是索引的字段,<value>是索引的方向,或是特殊的索引类型,如text2dsphereSee index types for the full list of index types.有关索引类型的完整列表,请参阅索引类型

Unexpected Shutdown and Count意外关机和计数

For MongoDB instances using the WiredTiger storage engine, after an unclean shutdown, statistics on size and count may off by up to 1000 documents as reported by collStats, dbStats, count. 对于使用WiredTiger存储引擎的MongoDB实例,在不干净地关闭后,collStatsdbStatscount报告的大小和计数统计数据最多可能会减少1000个文档。To restore the correct statistics for the collection, run validate on the collection.要恢复集合的正确统计信息,请对集合运行validate

In-Progress Indexes在建索引

Starting in MongoDB 4.2, the db.collection.stats includes information on indexes currently being built. 从MongoDB 4.2开始,db.collection.stats包含当前正在构建的索引的信息。For details, see:有关详细信息,请参阅:

Examples示例

Note

You can find the collection data used for these examples in our primer-dataset.json您可以在primer-dataset.json中找到用于这些示例的收集数据

Basic Stats Lookup基本统计数据查找

The following operation returns stats on the restaurants collection in the test database:以下操作返回test数据库中restaurants集合的统计信息:

db.restaurants.stats()

The operation returns:操作返回:

{
   "ns" : "test.restaurants",
   "size" : 7557340,
   "count" : 25359,
   "avgObjSize" : 298,
   "storageSize" : 9670656,
   "freeStorageSize" : 6660096,
   "capped" : false,
   "wiredTiger" : {
         "metadata" : {
            "formatVersion" : 1
         },
         "creationString" : "access_pattern_hint=none,allocation_size=4KB,app_metadata=(formatVersion=1),assert=(commit_timestamp=none,durable_timestamp=none,read_timestamp=none),block_allocation=best,block_compressor=snappy,cache_resident=false,checksum=on,colgroups=,collator=,columns=,dictionary=0,encryption=(keyid=,name=),exclusive=false,extractor=,format=btree,huffman_key=,huffman_value=,ignore_in_memory_cache_size=false,immutable=false,internal_item_max=0,internal_key_max=0,internal_key_truncate=true,internal_page_max=4KB,key_format=q,key_gap=10,leaf_item_max=0,leaf_key_max=0,leaf_page_max=32KB,leaf_value_max=64MB,log=(enabled=true),lsm=(auto_throttle=true,bloom=true,bloom_bit_count=16,bloom_config=,bloom_hash_count=8,bloom_oldest=false,chunk_count_limit=0,chunk_max=5GB,chunk_size=10MB,merge_custom=(prefix=,start_generation=0,suffix=),merge_max=15,merge_min=0),memory_page_image_max=0,memory_page_max=10m,os_cache_dirty_max=0,os_cache_max=0,prefix_compression=false,prefix_compression_min=4,source=,split_deepen_min_child=0,split_deepen_per_child=0,split_pct=90,type=file,value_format=u",
         "type" : "file",
         "uri" : "statistics:table:collection-43-6797839137631957852",
         "LSM" : {
            "bloom filter false positives" : 0,
            "bloom filter hits" : 0,
            "bloom filter misses" : 0,
            "bloom filter pages evicted from cache" : 0,
            "bloom filter pages read into cache" : 0,
            "bloom filters in the LSM tree" : 0,
            "chunks in the LSM tree" : 0,
            "highest merge generation in the LSM tree" : 0,
            "queries that could have benefited from a Bloom filter that did not exist" : 0,
            "sleep for LSM checkpoint throttle" : 0,
            "sleep for LSM merge throttle" : 0,
            "total size of bloom filters" : 0
         },
         "block-manager" : {
            "allocations requiring file extension" : 460,
            "blocks allocated" : 556,
            "blocks freed" : 420,
            "checkpoint size" : 2994176,
            "file allocation unit size" : 4096,
            "file bytes available for reuse" : 6660096,
            "file magic number" : 120897,
            "file major version number" : 1,
            "file size in bytes" : 9670656,
            "minor version number" : 0
         },
         "btree" : {
            "btree checkpoint generation" : 58,
            "column-store fixed-size leaf pages" : 0,
            "column-store internal pages" : 0,
            "column-store variable-size RLE encoded values" : 0,
            "column-store variable-size deleted values" : 0,
            "column-store variable-size leaf pages" : 0,
            "fixed-record size" : 0,
            "maximum internal page key size" : 368,
            "maximum internal page size" : 4096,
            "maximum leaf page key size" : 2867,
            "maximum leaf page size" : 32768,
            "maximum leaf page value size" : 67108864,
            "maximum tree depth" : 3,
            "number of key/value pairs" : 0,
            "overflow pages" : 0,
            "pages rewritten by compaction" : 0,
            "row-store empty values" : 0,
            "row-store internal pages" : 0,
            "row-store leaf pages" : 0
         },
         "cache" : {
            "bytes currently in the cache" : 19401033,
            "bytes dirty in the cache cumulative" : 28415209,
            "bytes read into cache" : 0,
            "bytes written from cache" : 31893695,
            "checkpoint blocked page eviction" : 0,
            "data source pages selected for eviction unable to be evicted" : 0,
            "eviction walk passes of a file" : 0,
            "eviction walk target pages histogram - 0-9" : 0,
            "eviction walk target pages histogram - 10-31" : 0,
            "eviction walk target pages histogram - 128 and higher" : 0,
            "eviction walk target pages histogram - 32-63" : 0,
            "eviction walk target pages histogram - 64-128" : 0,
            "eviction walks abandoned" : 0,
            "eviction walks gave up because they restarted their walk twice" : 0,
            "eviction walks gave up because they saw too many pages and found no candidates" : 0,
            "eviction walks gave up because they saw too many pages and found too few candidates" : 0,
            "eviction walks reached end of tree" : 0,
            "eviction walks started from root of tree" : 0,
            "eviction walks started from saved location in tree" : 0,
            "hazard pointer blocked page eviction" : 0,
            "in-memory page passed criteria to be split" : 4,
            "in-memory page splits" : 2,
            "internal pages evicted" : 0,
            "internal pages split during eviction" : 0,
            "leaf pages split during eviction" : 2,
            "modified pages evicted" : 2,
            "overflow pages read into cache" : 0,
            "page split during eviction deepened the tree" : 0,
            "page written requiring cache overflow records" : 0,
            "pages read into cache" : 0,
            "pages read into cache after truncate" : 1,
            "pages read into cache after truncate in prepare state" : 0,
            "pages read into cache requiring cache overflow entries" : 0,
            "pages requested from the cache" : 76607,
            "pages seen by eviction walk" : 0,
            "pages written from cache" : 552,
            "pages written requiring in-memory restoration" : 0,
            "tracked dirty bytes in the cache" : 0,
            "unmodified pages evicted" : 0
         },
         "cache_walk" : {
            "Average difference between current eviction generation when the page was last considered" : 0,
            "Average on-disk page image size seen" : 0,
            "Average time in cache for pages that have been visited by the eviction server" : 0,
            "Average time in cache for pages that have not been visited by the eviction server" : 0,
            "Clean pages currently in cache" : 0,
            "Current eviction generation" : 0,
            "Dirty pages currently in cache" : 0,
            "Entries in the root page" : 0,
            "Internal pages currently in cache" : 0,
            "Leaf pages currently in cache" : 0,
            "Maximum difference between current eviction generation when the page was last considered" : 0,
            "Maximum page size seen" : 0,
            "Minimum on-disk page image size seen" : 0,
            "Number of pages never visited by eviction server" : 0,
            "On-disk page image sizes smaller than a single allocation unit" : 0,
            "Pages created in memory and never written" : 0,
            "Pages currently queued for eviction" : 0,
            "Pages that could not be queued for eviction" : 0,
            "Refs skipped during cache traversal" : 0,
            "Size of the root page" : 0,
            "Total number of pages currently in cache" : 0
         },
         "compression" : {
            "compressed page maximum internal page size prior to compression" : 4096,
            "compressed page maximum leaf page size prior to compression " : 111392,
            "compressed pages read" : 0,
            "compressed pages written" : 548,
            "page written failed to compress" : 0,
            "page written was too small to compress" : 4
         },
         "cursor" : {
            "bulk loaded cursor insert calls" : 0,
            "cache cursors reuse count" : 74,
            "close calls that result in cache" : 0,
            "create calls" : 4,
            "insert calls" : 50718,
            "insert key and value bytes" : 24500283,
            "modify" : 0,
            "modify key and value bytes affected" : 0,
            "modify value bytes modified" : 0,
            "next calls" : 101747,
            "open cursor count" : 0,
            "operation restarted" : 0,
            "prev calls" : 1,
            "remove calls" : 0,
            "remove key bytes removed" : 0,
            "reserve calls" : 0,
            "reset calls" : 51000,
            "search calls" : 25359,
            "search near calls" : 25485,
            "truncate calls" : 0,
            "update calls" : 0,
            "update key and value bytes" : 0,
            "update value size change" : 0
         },
         "reconciliation" : {
            "dictionary matches" : 0,
            "fast-path pages deleted" : 0,
            "internal page key bytes discarded using suffix compression" : 1077,
            "internal page multi-block writes" : 1,
            "internal-page overflow keys" : 0,
            "leaf page key bytes discarded using prefix compression" : 0,
            "leaf page multi-block writes" : 12,
            "leaf-page overflow keys" : 0,
            "maximum blocks required for a page" : 1,
            "overflow values written" : 0,
            "page checksum matches" : 0,
            "page reconciliation calls" : 80,
            "page reconciliation calls for eviction" : 2,
            "pages deleted" : 0
         },
         "session" : {
            "object compaction" : 0
         },
         "transaction" : {
            "update conflicts" : 0
         }
   },
   "nindexes" : 4,
   "indexBuilds" : [ ],       // Available starting in MongoDB 4.2
   "totalIndexSize" : 704512,
   "totalSize" : 10375168,    // Available starting in MongoDB 4.4
   "indexSizes" : {
      "_id_" : 241664,
      "cuisine_1" : 147456,
      "borough_1_cuisine_1" : 159744,
      "borough_1_address.zipcode_1" : 155648
   },
   "scaleFactor" : 1,        // Available starting in MongoDB 4.2
   "ok" : 1
}

As stats was not give a scale parameter, all size values are in bytes.由于stats没有给出scale参数,所以所有大小值都以bytes(字节)为单位。

Stats Lookup With Scale按比例查找统计数据

The following operation changes the scale of data from bytes to kilobytes by specifying a scale of 1024:以下操作通过指定1024scale,将数据的刻度从bytes更改为kilobytes

db.restaurants.stats( { scale : 1024 } )

The operation returns:操作返回:

{
   "ns" : "test.restaurants",
   "size" : 7380,
   "count" : 25359,
   "avgObjSize" : 298,
   "storageSize" : 9444,
   "freeStorageSize" : 6504,
   "capped" : false,
   "wiredTiger" : {
      ...
   },
   "nindexes" : 4,
   "indexBuilds" : [ ],      // Available starting in MongoDB 4.2
   "totalIndexSize" : 688,
   "totalSize" : 10132,      // Available starting in MongoDB 4.4
   "indexSizes" : {
      "_id_" : 236,
      "cuisine_1" : 144,
      "borough_1_cuisine_1" : 156,
      "borough_1_address.zipcode_1" : 152
   },
   "scaleFactor" : 1024,     // Available starting in MongoDB 4.2
   "ok" : 1
}

Statistics Lookup With Index Details使用索引详细信息查找统计信息

The following operation creates an indexDetails document that contains information related to each of the indexes within the collection:以下操作将创建一个indexDetails文档,其中包含与集合中每个索引相关的信息:

db.restaurants.stats( { indexDetails : true } )

The operation returns:操作返回:

{
   "ns" : "test.restaurants",
   "size" : 7557340,
   "count" : 25359,
   "avgObjSize" : 298,
   "storageSize" : 9670656,
   "freeStorageSize" : 6660096,
   "capped" : false,
   "wiredTiger" : {
   ...
   },
   "nindexes" : 4,
   "indexDetails" : {
      "_id_" : {
         "metadata" : {
            "formatVersion" : 8
         },
         "creationString" : "access_pattern_hint=none,allocation_size=4KB,app_metadata=(formatVersion=8),assert=(commit_timestamp=none,durable_timestamp=none,read_timestamp=none),block_allocation=best,block_compressor=,cache_resident=false,checksum=on,colgroups=,collator=,columns=,dictionary=0,encryption=(keyid=,name=),exclusive=false,extractor=,format=btree,huffman_key=,huffman_value=,ignore_in_memory_cache_size=false,immutable=false,internal_item_max=0,internal_key_max=0,internal_key_truncate=true,internal_page_max=16k,key_format=u,key_gap=10,leaf_item_max=0,leaf_key_max=0,leaf_page_max=16k,leaf_value_max=0,log=(enabled=true),lsm=(auto_throttle=true,bloom=true,bloom_bit_count=16,bloom_config=,bloom_hash_count=8,bloom_oldest=false,chunk_count_limit=0,chunk_max=5GB,chunk_size=10MB,merge_custom=(prefix=,start_generation=0,suffix=),merge_max=15,merge_min=0),memory_page_image_max=0,memory_page_max=5MB,os_cache_dirty_max=0,os_cache_max=0,prefix_compression=true,prefix_compression_min=4,source=,split_deepen_min_child=0,split_deepen_per_child=0,split_pct=90,type=file,value_format=u",
         "type" : "file",
         "uri" : "statistics:table:index-44-6797839137631957852",
         "LSM" : {
         ...
         },
         "block-manager" : {
         ...
         },
         "btree" : {
         ...
         },
         "cache" : {
         ...
         },
         "cache_walk" : {
         ...
         },
         "compression" : {
         ...
         },
         "cursor" : {
         ...
         },
         "reconciliation" : {
         ...
         },
         "session" : {
         ...
         },
         "transaction" : {
         ...
         }
      },
      "cuisine_1" : {
         ...
      },
      "borough_1_cuisine_1" : {
         ...
      },
      "borough_1_address.zipcode_1" : {
         ...
   },
   "indexBuilds" : [ ],         // Available starting in MongoDB 4.2
   "totalIndexSize" : 704512,
   "totalSize" : 10375168,      // Available starting in MongoDB 4.4
   "indexSizes" : {
      "_id_" : 241664,
      "cuisine_1" : 147456,
      "borough_1_cuisine_1" : 159744,
      "borough_1_address.zipcode_1" : 155648
   },
   "scaleFactor" : 1,          // Available starting in MongoDB 4.2
   "ok" : 1
}

Statistics Lookup With Filtered Index Details使用筛选的索引详细信息进行统计查找

To filter the indexes in the indexDetails field, you can either specify the index keys using the indexDetailsKey option or specify the index name using the indexDetailsName. 要筛选indexDetails字段中的索引,可以使用indexDetailsKey选项指定索引键,也可以使用indexDetailsName指定索引名称。To discover index keys and names for the collection, use db.collection.getIndexes().要查找集合的索引键和名称,请使用db.collection.getIndexes()

Given the following index:考虑到以下指标:

{
   "ns" : "test.restaurants",
   "v" : 1,
   "key" : {
      "borough" : 1,
      "cuisine" : 1
   },
   "name" : "borough_1_cuisine_1"
}

The following operation filters the indexDetails document to a single index as defined by the indexDetailsKey document.以下操作将indexDetails文档筛选为indexDetailsKey文档定义的单个索引。

db.restaurants.stats(
   {
      'indexDetails' : true,
      'indexDetailsKey' :
      {
         'borough' : 1,
         'cuisine' : 1
      }
   }
)

The following operation filters the indexDetails document to a single index as defined by the indexDetailsName document.以下操作将indexDetails文档筛选为indexDetailsName文档定义的单个索引。

db.restaurants.stats(
   {
      'indexDetails' : true,
      'indexDetailsName' : 'borough_1_cuisine_1'
   }
)

Both operations will return the same output:两个操作将返回相同的输出:

{
   "ns" : "test.restaurants",
   "size" : 7557340,
   "count" : 25359,
   "avgObjSize" : 298,
   "storageSize" : 9670656,
   "freeStorageSize" : 6660096,
   "capped" : false,
   "wiredTiger" : {
      ...
   },
   "nindexes" : 4,
   "indexDetails" : {
      "borough_1_cuisine_1" : {
         "metadata" : {
            "formatVersion" : 8
         },
         "LSM" : {
            ...
         },
         "block-manager" : {
            ...
         },
         "btree" : {
            ...
         },
         "cache" : {
            ...
         },
         "cache_walk" : {
            ...
         },
         "compression" : {
            ...
         },
         "cursor" : {
            ...
         },
         "reconciliation" : {
            ...
         },
         "session" : {
            ...
         },
         "transaction" : {
            ...
         }
      }
   },
   "indexBuilds" : [ ],          // Available starting in MongoDB 4.2
   "totalIndexSize" : 704512,
   "totalSize" : 10375168,       // Available starting in MongoDB 4.4
   "indexSizes" : {
      "_id_" : 241664,
      "cuisine_1" : 147456,
      "borough_1_cuisine_1" : 159744,
      "borough_1_address.zipcode_1" : 155648
   },
   "scaleFactor" : 1,            // Available starting in MongoDB 4.2
   "ok" : 1
}

For explanation of the output, see output details.有关输出的说明,请参阅输出详细信息

See also参阅

$collStats