Definition定义
Use the 使用$collStats aggregation stage instead of the collStats command and its mongosh helper method db.collection.stats().$collStats聚合阶段,而不是collStats命令及其mongosh辅助方法db.collection.stats()。
db.collection.stats(<option>)-
Important
mongosh
Method方法This page documents a本页记录了一种mongoshmethod. This is not the documentation for database commands or language-specific drivers, such as Node.js.mongosh方法。这不是数据库命令或特定语言驱动程序(如Node.js)的文档。For the database command, see the关于数据库命令,请参阅collStatscommand.collStats命令。For MongoDB API drivers, refer to the language-specific MongoDB driver documentation.有关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描述scalenumber数字Optional.可选。The scale factor for the various size data.各种大小数据的比例因子。Thescaledefaults to 1 to return size data in bytes.scale默认为1,以字节为单位返回大小数据。To display kilobytes rather than bytes, specify a要显示千字节而不是字节,请指定scalevalue of1024.1024的scale值。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 uses1023as the scale factor.1023.999,MongoDB将使用1023作为比例因子。Starting in version 4.2, the output includes the从4.2版本开始,输出包括用于缩放大小值的scaleFactorused to scale the size values.scaleFactor。indexDetailsboolean布尔值Optional.可选。If如果为true,db.collection.stats()returnsindex detailsin addition to the collection stats.true,db.collection.stats()除了返回集合统计信息外,还返回索引详细信息。Only works for WiredTiger storage engine.仅适用于WiredTiger存储引擎。Defaults to默认为false.false。indexDetailsKeydocument文档Optional.可选。If如果indexDetailsistrue, you can useindexDetailsKeyto filter index details by specifying the index key specification. Only the index that exactly matchesindexDetailsKeywill be returned.indexDetails为true,则可以使用indexDetailsKey通过指定索引键规范来筛选索引详细信息。只会返回与indexDetailsKey完全匹配的索引。If no match is found,如果找不到匹配项,indexDetailswill display statistics for all indexes.indexDetails将显示所有索引的统计信息。Use使用getIndexes()to discover index keys.getIndexes()来发现索引键。You cannot use不能将indexDetailsKeywithindexDetailsName.indexDetailsKey与indexDetailsName一起使用。indexDetailsNamestring字符串Optional.可选。If如果indexDetailsistrue, you can useindexDetailsNameto filter index details by specifying the indexname. Only the index name that exactly matchesindexDetailsNamewill be returned.indexDetails为true,则可以使用indexDetailsName通过指定索引name来筛选索引详细信息。只会返回与indexDetailsName完全匹配的索引名称。If no match is found,如果找不到匹配项,indexDetailswill display statistics for all indexes.indexDetails将显示所有索引的统计信息。Use使用getIndexes()to discover index names. You cannot useindexDetailsNamewithindexDetailsField.getIndexes()查找索引名称。不能将indexDetailsName与indexDetailsField一起使用。To specify just the为了仅指定比例因子,MongoDB支持传统格式:scalefactor, MongoDB supports the legacy format:db.collection.stats(<number>)Returns:返回A document that contains statistics on the specified collection.包含指定集合统计信息的文档。See有关返回的统计信息的细分,请参阅collStatsfor a breakdown of the returned statistics.collStats。
Compatibility兼容性
This method is available in deployments hosted in the following environments:此方法在以下环境中托管的部署中可用:
- MongoDB Atlas
: The fully managed service for MongoDB deployments in the cloud:云中MongoDB部署的完全托管服务
Note
This command is supported in all MongoDB Atlas clusters. 所有MongoDB Atlas集群都支持此命令。For information on Atlas support for all commands, see Unsupported Commands.有关Atlas支持所有命令的信息,请参阅不支持的命令。
- MongoDB Enterprise
: The subscription-based, self-managed version of MongoDB:MongoDB的基于订阅的自我管理版本 - MongoDB Community
: The source-available, free-to-use, and self-managed version of MongoDB:MongoDB的源代码可用、免费使用和自我管理版本
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 在使用Wired Tiger存储引擎不干净地关闭mongod using the Wired Tiger storage engine, count and size statistics reported by db.collection.stats() may be inaccurate.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. However, 检查点通常每60秒出现一次。然而,使用非默认的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 statistics after an unclean shutdown.mongod上的每个集合上运行validate,以在不干净关闭后恢复统计数据。
After an unclean shutdown:不干净停机后:
Replica Set Member State Restriction副本集成员状态限制
To run on a replica set member, 要在副本集成员上运行,collStats operations require the member to be in PRIMARY or SECONDARY state. collStats操作要求该成员处于PRIMARY或SECONDARY状态。If the member is in another state, such as 如果成员处于另一种状态,如STARTUP2, the operation errors.STARTUP2,则操作错误。
Index Filter Behavior索引筛选器行为
Filtering on 使用indexDetails using either indexDetailsKey or indexDetailsName will only return a single matching index. If no exact match is found, indexDetails will show information on all indexes for the collection.indexDetailsKey或indexDetailsName对indexDetails进行筛选将只返回一个匹配的索引。如果找不到完全匹配,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>是索引的方向,或者是特殊的索引类型,如text或2dsphere。See index types for the full list of index types.有关索引类型的完整列表,请参阅索引类型。
Starting in MongoDB 8.0, use query settings instead of adding index filters. Index filters are deprecated starting in MongoDB 8.0.从MongoDB 8.0开始,使用查询设置,而不是添加索引筛选器。索引筛选器从MongoDB 8.0开始就被弃用。
Query settings have more functionality than index filters. Also, index filters aren't persistent and you cannot easily create index filters for all cluster nodes. 查询设置比索引筛选器具有更多功能。此外,索引筛选器不是持久的,您无法轻松为所有集群节点创建索引筛选器。To add query settings and explore examples, see 要添加查询设置并探索示例,请参阅setQuerySettings.setQuerySettings。
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 对于使用WiredTiger存储引擎的MongoDB实例,在不干净关闭后,collStats, dbStats, count. collStats、dbStats、count报告的大小和计数统计数据可能会减少多达1000个文档。To restore the correct statistics for the collection, run 若要还原集合的正确统计信息,请对集合运行validate on the collection.validate。
In-Progress Indexes进行中索引
The db.collection.stats() includes information on indexes currently being built. For details, see:db.collection.stats()包含有关当前正在构建的索引的信息。有关详细信息,请参阅:
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" : [ ],
"totalIndexSize" : 704512,
"totalSize" : 10375168,
"indexSizes" : {
"_id_" : 241664,
"cuisine_1" : 147456,
"borough_1_cuisine_1" : 159744,
"borough_1_address.zipcode_1" : 155648
},
"scaleFactor" : 1,
"ok" : 1
}
As stats was not give a scale parameter, all size values are in 由于统计数据没有给出缩放参数,所有大小值都以bytes.bytes为单位。
Stats Lookup With Scale按比例查找统计数据
The following operation changes the scale of data from 以下操作通过指定bytes to kilobytes by specifying a scale of 1024:1024的scale将数据的缩放数从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" : [ ],
"totalIndexSize" : 688,
"totalSize" : 10132,
"indexSizes" : {
"_id_" : 236,
"cuisine_1" : 144,
"borough_1_cuisine_1" : 156,
"borough_1_address.zipcode_1" : 152
},
"scaleFactor" : 1024,
"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" : [ ],
"totalIndexSize" : 704512,
"totalSize" : 10375168,
"indexSizes" : {
"_id_" : 241664,
"cuisine_1" : 147456,
"borough_1_cuisine_1" : 159744,
"borough_1_address.zipcode_1" : 155648
},
"scaleFactor" : 1,
"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" : [ ],
"totalIndexSize" : 704512,
"totalSize" : 10375168,
"indexSizes" : {
"_id_" : 241664,
"cuisine_1" : 147456,
"borough_1_cuisine_1" : 159744,
"borough_1_address.zipcode_1" : 155648
},
"scaleFactor" : 1,
"ok" : 1
}
For explanation of the output, see output details.有关输出的说明,请参阅输出详细信息。