serverStatus
在此页面上
- 定义
- 兼容性
- 语法
- 行为
- 初始化
- 包括
mirroredReads
- 包括
latchAnalysis
- 包括
latchAnalysis
- 更改
tcmalloc
详细程度 - 输出
- 断言
- bucketCatalog
- 连接
- defaultRWConcern
- electionMetrics
- extra_info
- flowControl
- globalLock
- hedgingMetrics
- IndexBulkBuilder
- 实例信息
- latchAnalysis
- 锁
- logicalSessionRecordCache
- mem
- 衡量标准
- 镜像读 (Mirrored Reads)
- 网络
- opLatencies
- opReadConcernCounters
- opWriteConcernCounters
- 运算计数器
- opcountersRepl
- oplogTruncation
- readConcernCounters
- repl
- 安全性
- 分片
- shardingStatistics
- shardedIndexConsistency
- 引擎加密
- 事务
- transportSecurity
- watchdog
- WiredTiger
- writeBacksQueued
定义
serverStatus
serverStatus
命令返回一个提供数据库状态概述的文档。监控应用程序可以定期运行此命令,以收集有关实例的统计信息。
兼容性
此命令可用于以下环境中托管的部署:
MongoDB Atlas:用于云中 MongoDB 部署的完全托管服务
注意
所有 MongoDB Atlas 集群都支持此命令。有关 Atlas 对所有命令的支持的信息,请参阅不支持的命令。
MongoDB Enterprise:基于订阅、自我管理的 MongoDB 版本
MongoDB Community:源代码可用、免费使用且可自行管理的 MongoDB 版本
语法
该命令具有以下语法:
db.runCommand( { serverStatus: 1 } )
值(即上面的 1
)不会影响该命令的操作。db.serverStatus()
命令将返回大量数据。要从输出中返回特定对象或字段,请在命令后附加对象或字段名称。
例如:
db.runCommand({ serverStatus: 1}).metrics db.runCommand({ serverStatus: 1}).metrics.commands db.runCommand({ serverStatus: 1}).metrics.commands.update
mongosh
为命令 serverStatus
提供 db.serverStatus()
包装器。
行为
默认情况下,serverStatus
在输出中排除:
repl 文档中的一些内容。
mirroredReads 文档。
要包含默认排除的字段,请在命令中指定顶层字段并将其设置为 1
。要排除默认包含的字段,请指定该字段并将其设置为 0。您可以指定顶层字段或嵌入字段。
例如,以下操作会排除输出中的 repl
、metrics
和locks
信息。
db.runCommand( { serverStatus: 1, repl: 0, metrics: 0, locks: 0 } )
例如,以下操作会排除输出中嵌入的 histogram
字段。
db.runCommand( { serverStatus: 1, metrics: { query: { multiPlanner: { histograms: false } } } } )
以下示例在输出中包含所有 repl 信息:
db.runCommand( { serverStatus: 1, repl: 1 } )
初始化
serverStatus
报告的统计信息将在 mongod
服务器重启时重置。
此命令将始终返回一个值,即使对新数据库也是如此。除非特定指标的计数器开始增加,否则,相关命令 db.serverStatus()
并不总是返回值。
运行更新查询后,db.serverStatus()
和db.runCommand({ serverStatus: 1})
都返回相同的值。
{ arrayFilters : Long("0"), failed : Long("0"), pipeline : Long("0"), total : Long("1") }
包括 mirroredReads
默认情况下,输出中不包含 mirroredReads
信息。如要返回 mirroredReads
信息,必须明确指定包含的内容:
db.runCommand( { serverStatus: 1, mirroredReads: 1 } )
包括 latchAnalysis
默认情况下,输出中不包含latchAnalysis
信息(从版本4.4开始提供)。 要返回latchAnalysis
信息,必须明确指定包含的内容:
db.runCommand( { serverStatus: 1, latchAnalysis: 1 } )
包括 latchAnalysis
默认情况下,输出中不包含 latchAnalysis
信息。如要返回 latchAnalysis
信息,必须明确指定包含的内容:
db.runCommand( { serverStatus: 1, latchAnalysis: 1 } )
更改tcmalloc
详细程度
默认情况下,输出中包含 tcmalloc
信息。本部分提供数据库的内存分配统计信息。要更改 tcmalloc
部分的详细程度,请指定一个介于 0
和2
(含)之间的整数:
db.runCommand( { serverStatus: 1, tcmalloc: <int> } )
该命令的行为如下:
默认情况下,
tcmalloc
设置为1
。传递较大的整数值会提高详细程度。
传递
0
或false
将忽略输出中的tcmalloc
部分。传递任何其他输入都会采用默认设置。
有关 MongoDB 如何分配内存的更多信息,请参阅 TcMalloc。
输出
注意
输出字段因 MongoDB 的版本、底层操作系统平台、存储引擎和节点类型(包括 mongos
、mongod
或副本集节点)不同而异。
有关特定于 MongoDB 版本的 serverStatus
输出,请参阅 MongoDB 手册的相应版本。
断言
asserts : { regular : <num>, warning : <num>, msg : <num>, user : <num>, rollovers : <num> },
asserts
一个文档,其中报告自 MongoDB 进程启动以来引发的断言数量。断言是对数据库运行时发生的错误的内部检查,可以帮助诊断 MongoDB 服务器的问题。非零断言值表示断言错误,这种错误并不常见,也不是什么值得立即关注的问题。生成断言的错误可以记录在日志文件中,或直接返回到客户端应用程序以获取更多信息。
asserts.user
自上次启动 MongoDB 进程以来发生的“用户断言”的数量。这些是用户可能生成的错误,例如磁盘空间不足或重复密钥。您可以通过修复应用程序或部署的问题来防止这些断言。检查日志文件以获取有关这些消息的详细信息。
asserts.rollovers
自 MongoDB 进程上次启动以来,断言计数器翻转的次数。在 2 30 次断言之后,计数器将翻转为零。使用该值可为
asserts
数据结构中的其他值提供上下文。
bucketCatalog
bucketCatalog : { numBuckets : <num>, numOpenBuckets : <num>, numIdleBuckets : <num>, memoryUsage : <num> }
版本 5.0 中的新增功能。
报告时间序列集合的内部存储相关指标的文档。
bucketCatalog
返回以下指标:
衡量标准 | 说明 |
---|---|
| 内部存储时间序列数据的存储桶的数量。 |
| 活动的、未提交的写入存储桶的数量。 |
| 未满且可存储传入的时间序列数据的存储桶的数量。 |
| 内部分桶数据结构使用的字节数。 |
版本 5.0 中的新增功能。
连接
connections : { current : <num>, available : <num>, totalCreated : <num>, active : <num>, threaded : <num>, exhaustIsMaster : <num>, exhaustHello : <num>, awaitingTopologyChanges : <num>, loadBalanced : <num> },
connections.current
从客户端到数据库服务器的传入连接数。该数字包括当前 Shell 会话。考虑
connections.available
的值,为该数据添加更多上下文。
connections.available
可用的未使用传入连接数。将此值与
connections.current
的值结合,可了解数据库的连接负载;将此值与 UNIXulimit
自管理部署设置文档结合,可了解有关可用连接系统阈值的更多信息。
connections.exhaustIsMaster
最后一个请求是指定 exhausAllowed 的
isMaster
请求的连接的数量。注意
如果运行的是 MongoDB 5.0 或更高版本,请勿使用
isMaster
命令。请改用hello
。
connections.exhaustHello
最后请求是指定 ExhaustAllowed 的
hello
请求的连接的数量。版本 5.0 中的新增功能。
defaultRWConcern
defaultRWConcern
部分提供有关全局默认读关注或写关注设置的本地副本的信息。数据可能已过时或已过期。有关更多信息,请参阅 getDefaultRWConcern
。
defaultRWConcern : { defaultReadConcern : { level : <string> }, defaultWriteConcern : { w : <string> | <int>, wtimeout : <int>, j : <bool> }, defaultWriteConcernSource: <string>, defaultReadConcernSource: <string>, updateOpTime : Timestamp, updateWallClockTime : Date, localUpdateWallClockTime : Date }
defaultRWConcern.defaultReadConcern
上次已知的全局默认读关注设置。
如果
serverStatus
未返回此字段,则全局默认读关注尚未设置或尚未传播到实例。
defaultRWConcern.defaultReadConcern.level
上次已知的全局默认读关注级别设置。
如果
serverStatus
未返回此字段,则表示该设置的全局默认值尚未设置或尚未传播到实例。
defaultRWConcern.defaultWriteConcern
上次已知的全局默认写关注设置。
如果
serverStatus
未返回此字段,则全局默认写关注尚未设置或者 尚未传播到实例。
defaultRWConcern.defaultWriteConcern.w
上次已知的全局默认 w 设置。
如果
serverStatus
未返回此字段,则表示该设置的全局默认值尚未设置或尚未传播到实例。
defaultRWConcern.defaultWriteConcern.wtimeout
上次已知的全局默认 wtimeout 设置。
如果
serverStatus
未返回此字段,则表示该设置的全局默认值尚未设置或尚未传播到实例。
defaultRWConcern.defaultWriteConcernSource
默认写关注的来源。默认情况下,该值为
"implicit"
。使用setDefaultRWConcern
完成设置默认写关注后,该值即变为"global"
。版本 5.0 中的新增功能。
defaultRWConcern.defaultReadConcernSource
默认读关注的来源。默认情况下,该值为
"implicit"
。使用setDefaultRWConcern
完成设置默认读关注后,该值即变为"global"
。版本 5.0 中的新增功能。
defaultRWConcern.updateOpTime
该实例上次更新其任何全局读关注或写关注设置副本的时间戳。如果没有
defaultRWConcern.defaultReadConcern
和defaultRWConcern.defaultWriteConcern
字段,则此字段指示上次取消设置默认值的时间戳。
defaultRWConcern.updateWallClockTime
该实例上次更新其任何全局读关注或写关注设置副本的挂钟时间。如果没有
defaultRWConcern.defaultReadConcern
和defaultRWConcern.defaultWriteConcern
字段,则此字段指示上次取消设置默认值的时间。
defaultRWConcern.localUpdateWallClockTime
该实例上次更新其任何全局读关注或写关注设置副本的本地系统挂钟时间。如果此字段是
defaultRWConcern
下的唯一 字段,则该实例从不了解全局默认读关注或写关注设置。
electionMetrics
electionMetrics
部分提供有关此 mongod
实例试图成为主节点而调用的选举的信息:
electionMetrics : { stepUpCmd : { called : Long("<num>"), successful : Long("<num>") }, priorityTakeover : { called : Long("<num>"), successful : Long("<num>") }, catchUpTakeover : { called : Long("<num>"), successful : Long("<num>") }, electionTimeout : { called : Long("<num>"), successful : Long("<num>") }, freezeTimeout : { called : Long("<num>"), successful : Long("<num>") }, numStepDownsCausedByHigherTerm : Long("<num>"), numCatchUps : Long("<num>"), numCatchUpsSucceeded : Long("<num>"), numCatchUpsAlreadyCaughtUp : Long("<num>"), numCatchUpsSkipped : Long("<num>"), numCatchUpsTimedOut : Long("<num>"), numCatchUpsFailedWithError : Long("<num>"), numCatchUpsFailedWithNewTerm : Long("<num>"), numCatchUpsFailedWithReplSetAbortPrimaryCatchUpCmd : Long("<num>"), averageCatchUpOps : <double> }
electionMetrics.priorityTakeover
mongod
实例调用的选举指标,因为其priority
高于主节点。electionMetrics.priorityTakeover
既包括调用的选举次数,也包括成功的选举次数。
electionMetrics.catchUpTakeover
mongod
实例调用的选举指标,因为它比主节点的日期更近。catchUpTakeover
既包括调用的选举次数,也包括成功的选举次数。
electionMetrics.electionTimeout
mongod
实例调用的选举指标,因为它无法在settings.electionTimeoutMillis
内到达主节点。electionTimeout
既包括调用的选举次数,也包括成功的选举次数。
electionMetrics.freezeTimeout
mongod
实例在其freeze period
(在此期间,节点无法寻求选举)到期后调用的选举指标。electionMetrics.freezeTimeout
既包括调用的选举次数,也包括成功的选举次数。
electionMetrics.numStepDownsCausedByHigherTerm
mongod
实例因看到更高任期(具体来说,其他节点参与了额外选举)而降级的次数。
electionMetrics.numCatchUps
作为新当选主节点的
mongod
实例必须赶上已知最高 oplog 条目的选举次数。
electionMetrics.numCatchUpsSucceeded
作为新当选主节点的
mongod
实例成功赶上已知最高 oplog 条目的次数。
electionMetrics.numCatchUpsAlreadyCaughtUp
作为新当选主节点的
mongod
实例由于当选时已被赶上而结束其追赶进程的次数。
electionMetrics.numCatchUpsSkipped
作为新当选主节点的
mongod
实例跳过追赶进程的次数。
electionMetrics.numCatchUpsTimedOut
作为新当选主节点的
mongod
实例由于settings.catchUpTimeoutMillis
限制而结束其追赶进程的次数。
electionMetrics.numCatchUpsFailedWithReplSetAbortPrimaryCatchUpCmd
由于
mongod
收到replSetAbortPrimaryCatchUp
命令而导致新当选主节点的追赶进程结束的次数。
extra_info
extra_info : { note : 'fields vary by platform', page_faults : <num> },
extra_info.page_faults
页面错误总数。
extra_info.page_faults
计数器在性能不佳的时刻可能会急剧增加,并且可能与内存环境有限和数据集较大相关。有限且偶发的页面错误并不一定表明存在问题。Windows 区分涉及磁盘 I/O 的“硬”页面错误与仅需要在内存中移动页面的“软”页面错误。MongoDB 在该统计中同时计入硬页面错误和软页面错误。
flowControl
flowControl : { enabled : <boolean>, targetRateLimit : <int>, timeAcquiringMicros : Long("<num>"), locksPerKiloOp : <double>, sustainerRate : <int>, isLagged : <boolean>, isLaggedCount : <int>, isLaggedTimeMicros : Long("<num>") },
flowControl
返回流量控制统计信息的文档。启用流量控制后,随着
majority commit
点滞后逐渐接近flowControlTargetLagSeconds
,主节点上的写入操作先获取票证才能获取锁。因此,在主节点上运行时,返回的指标很有意义。
flowControl.enabled
一个布尔值,用于表示流量控制处于启用状态 (
true
) 还是禁用状态 (false
)。另请参阅
enableFlowControl
。
flowControl.isLagged
在主节点上运行时,为一个布尔值,指示流量控制是否已启用。当多数提交延迟大于配置的
flowControlTargetLagSeconds
的某个百分比时,将会启用流量控制。在从节点上运行时,返回的布尔值是占位符。
flowControl.isLaggedCount
在主节点上运行时,流量控制自上次重启以来启用的次数。当多数提交延迟大于
flowControlTargetLagSeconds
的某个百分比时,将会启用流量控制。在从节点上运行时,返回的数字是占位符。
flowControl.isLaggedTimeMicros
在主节点上运行时,流量控制自上次重启以来启用所用的时间。当多数提交延迟大于
flowControlTargetLagSeconds
的某个百分比时,将会启用流量控制。在从节点上运行时,返回的数字是占位符。
globalLock
globalLock : { totalTime : Long("<num>"), currentQueue : { total : <num>, readers : <num>, writers : <num> }, activeClients : { total : <num>, readers : <num>, writers : <num> } },
globalLock
一个文档,其中报告数据库锁定状态。
一般来说,锁文档会提供有关锁使用情况的更详细数据。
globalLock.totalTime
自数据库上次启动并创建
globalLock
以来的时间(以微秒为单位)。这约等于服务器的总计正常运行时间。
globalLock.currentQueue.total
排队等待锁定的操作总数(即
globalLock.currentQueue.readers
和globalLock.currentQueue.writers
的总和)。不必担心持续较小的队列,特别是短操作的队列。
globalLock.activeClients
读取者和写入者信息为该数据提供了上下文。
globalLock.activeClients
提供已连接客户端数量以及这些客户端执行的读写操作相关信息的文档。
利用该数据为
globalLock.currentQueue
数据提供上下文。
hedgingMetrics
仅适用于 mongos
实例。
hedgingMetrics : { numTotalOperations : <num>, numTotalHedgedOperations : <num>, numAdvantageouslyHedgedOperations : <num> },
IndexBulkBuilder
indexBulkBuilder: { count: <long>, resumed: <long>, filesOpenedForExternalSort: <long>, filesClosedForExternalSort: <long> }
indexBulkBuilder
提供索引批量构建器操作的指标。使用这些指标可诊断使用
createIndexes
构建索引的问题、初始同步期间的集合克隆、启动后恢复的索引构建,以及外部排序器磁盘使用情况的统计信息。
indexBulkBuilder.filesClosedForExternalSort
外部排序器关闭文件句柄以将数据溢写到磁盘的次数。将此值与
filesOpenedForExternalSort
相结合,可确定外部排序器正在使用的打开文件句柄数。
indexBulkBuilder.filesOpenedForExternalSort
外部排序器打开文件句柄以将数据溢写到磁盘的次数。将此值与
filesClosedForExternalSort
相结合,可确定外部排序器正在使用的打开文件句柄数。
实例信息
host : <string>, advisoryHostFQDNs : <array>, version : <string>, process : <'mongod'|'mongos'>, pid : Long("<num>"), uptime : <num>, uptimeMillis : Long("<num>"), uptimeEstimate : Long("<num>"), localTime : ISODate("<Date>"),
latchAnalysis
4.4 版本新增。
latchAnalysis : { <latch name> : { created : <num>, destroyed : <num>, acquired : <num>, released : <num>, contended : <num>, hierarchicalAcquisitionLevelViolations : { onAcquire : <num>, onRelease : <num> } }, ...
latchAnalysis
一份报告与内部锁原语(也称为闩锁)相关的指标的文档。
如要返回
latchAnalysis
信息,您必须明确指定包含的内容:db.runCommand( { serverStatus: 1, latchAnalysis: 1 } ) latchAnalysis
为每个锁存器返回<latch name>
和以下关联指标:衡量标准说明created
创建锁存器的次数。
destroyed
销毁锁存器的次数。
acquired
获取闩锁的次数。
released
释放锁存器的次数。
contended
闩锁发生争用的次数。
hierarchicalAcquisitionLevelViolations
仅当存在违规时才返回
包含以下字段:
onAcquire
在获取闩锁期间违反闩锁层次结构(即闩锁级别顺序)的次数。
onRelease
在释放闩锁期间违反闩锁层次结构(即闩锁级别顺序)的次数。
4.4 版本新增。
锁
locks : { <type> : { acquireCount : { <mode> : Long("<num>"), ... }, acquireWaitCount : { <mode> : Long("<num>"), ... }, timeAcquiringMicros : { <mode> : Long("<num>"), ... }, deadlockCount : { <mode> : Long("<num>"), ... } }, ...
locks
报告每个锁
<type>
以及锁<modes>
上的数据的文档。可能的锁
<types>
是:锁类型说明ParallelBatchWriterMode
代表并行批量写入模式的锁。
在早期版本中,PBWM 信息作为
Global
锁信息的一部分进行报告。ReplicationStateTransition
表示副本集节点状态转换采用的锁。
Global
代表全局锁定。
Database
代表数据库锁。
Collection
代表集合锁。
Mutex
代表互斥锁。
Metadata
代表元数据锁。
oplog
表示 oplog 上的锁。
可能的
<modes>
是:锁模式说明R
代表共享(S)锁。
W
代表独占 (X) 锁。
r
代表意向共享(IS)锁。
w
代表意图独占 (IX) 锁。
所有值均为
Long()
类型。
locks.<type>.acquireWaitCount
由于锁以冲突模式被占用而导致
locks.<type>.acquireCount
锁获取遇到等待的次数。
locks.<type>.timeAcquiringMicros
锁获取的累积等待时间(以微秒为单位)。
locks.<type>.timeAcquiringMicros
除以locks.<type>.acquireWaitCount
得出特定锁模式的大致平均等待时间。
logicalSessionRecordCache
版本 3.6 中的新增功能。
logicalSessionRecordCache : { activeSessionsCount : <num>, sessionsCollectionJobCount : <num>, lastSessionsCollectionJobDurationMillis : <num>, lastSessionsCollectionJobTimestamp : <Date>, lastSessionsCollectionJobEntriesRefreshed : <num>, lastSessionsCollectionJobEntriesEnded : <num>, lastSessionsCollectionJobCursorsClosed : <num>, transactionReaperJobCount : <num>, lastTransactionReaperJobDurationMillis : <num>, lastTransactionReaperJobTimestamp : <Date>, lastTransactionReaperJobEntriesCleanedUp : <num>, sessionCatalogSize : <num> },
logicalSessionRecordCache
提供有关服务器会话缓存的指标。
logicalSessionRecordCache.sessionsCollectionJobCount
跟踪刷新进程在
config.system.sessions
集合上运行的次数的数字。
logicalSessionRecordCache.lastSessionsCollectionJobCursorsClosed
上次刷新
config.system.sessions
集合时关闭的游标数。
logicalSessionRecordCache.transactionReaperJobCount
跟踪事务记录清理过程在
config.transactions
集合上运行次数的数字。
logicalSessionRecordCache.lastTransactionReaperJobEntriesCleanedUp
在上次清理事务记录期间删除的
config.transactions
集合中的条目数。
logicalSessionRecordCache.sessionCatalogSize
- 对于
mongod
实例, config.transactions
条目的内存缓存的大小。这对应于会话在localLogicalSessionTimeoutMinutes
内未过期的可重试写入或事务。
- 对于
- 对于
mongos
实例, - 包含最近
localLogicalSessionTimeoutMinutes
间隔内的事务的会话的内存缓存数量。
- 对于
mem
mem : { bits : <int>, resident : <int>, virtual : <int>, supported : <boolean> },
mem
一个文档,其中报告
mongod
的系统架构和当前内存使用情况。
mem.resident
mem.resident
的值大致等于数据库进程当前使用的 RAM 量,以兆字节 (MiB) 为单位。在正常使用期间,此值往往会增长。在专用数据库服务器中,此数字往往接近系统内存总量。
mem.virtual
mem.virtual
显示mongod
进程使用的虚拟内存量,以兆字节 (MiB) 为单位。
mem.supported
指示底层系统是否支持扩展内存信息的布尔值。如果此值为 false 且系统不支持扩展内存信息,则数据库服务器可能无法访问其他
mem
值。
mem.note
字段
mem.note
出现的条件:mem.supported
为 false。mem.note
字段包含文本:'not all mem info support on this platform'
。
衡量标准
metrics : { apiVersions: { <appName1>: <string>, <appName2>: <string>, <appName3>: <string> }, aggStageCounters : { <aggregation stage> : Long("<num>") }, changeStreams: { largeEventsFailed: Long("<num>") }, commands: { <command>: { failed: Long("<num>"), validator: { total: Long("<num>"), failed: Long("<num>"), jsonSchema: Long("<num>") }, total: Long("<num>") } }, cursor : { moreThanOneBatch : Long("<num>"), timedOut : Long("<num>"), totalOpened : Long("<num>"), lifespan : { greaterThanOrEqual10Minutes : Long("<num>"), lessThan10Minutes : Long("<num>"), lessThan15Seconds : Long("<num>"), lessThan1Minute : Long("<num>"), lessThan1Second : Long("<num>"), lessThan30Seconds : Long("<num>"), lessThan5Seconds : Long("<num>") }, open : { noTimeout : Long("<num>"), pinned : Long("<num>"), multiTarget : Long("<num>"), singleTarget : Long("<num>"), total : Long("<num>") } }, document : { deleted : Long("<num>"), inserted : Long("<num>"), returned : Long("<num>"), updated : Long("<num>") }, dotsAndDollarsFields : { inserts : Long("<num>"), updates : Long("<num>") }, getLastError : { wtime : { num : <num>, totalMillis : <num> }, wtimeouts : Long("<num>"), default : { unsatisfiable : Long("<num>"), wtimeouts : Long("<num>") } }, mongos : { cursor : { moreThanOneBatch : Long("<num>"), totalOpened : Long("<num>") } }, operation : { scanAndOrder : Long("<num>"), writeConflicts : Long("<num>") }, operatorCounters : { expressions : { <command> : Long(<num>) }, match : { <command> : Long(<num>) } }, query: { allowDiskUseFalse: Long("<num>"), planCacheTotalSizeEstimateBytes: Long("<num>"), updateOneOpStyleBroadcastWithExactIDCount: Long("<num>"), lookup: { pipelineTotalCount: Long("<num>"), slotBasedExecutionCounters: { hashLookup: Long("<num>"), hashLookupSpillToDisk: Long("<num>"), indexedLoopJoin: Long("<num>"), nestedLoopJoin: Long("<num>") } }, multiPlanner: { classicCount: Long("<num>"), classicMicros: Long("<num>"), classicWorks: Long("<num>"), sbeCount: Long("<num>"), sbeMicros: Long("<num>"), sbeNumReads: Long("<num>"), histograms: { classicMicros: [ { lowerBound: Long("0"), count: Long("<num>") }, { < Additional histogram groups not shown. > }, { lowerBound: Long("1073741824"), count: Long("<num>")> }> ], classicNumPlans: [ { lowerBound: Long("0"), count: Long("<num>") }, { < Additional histogram groups not shown. > }, { lowerBound: Long("32"), count: Long("<num>") } ], classicWorks: [ { lowerBound: Long("0"), count: Long("<num>") }, { < Additional histogram groups not shown. > }, { lowerBound: Long("32768"), count: Long("<num>") } ], sbeMicros: [ { lowerBound: Long("0"), count: Long("<num>") }, { < Additional histogram groups not shown. > }, { lowerBound: Long("1073741824"), count: Long("<num>") } ], sbeNumPlans: [ { lowerBound: Long("0"), count: Long("<num>") }, { < Additional histogram groups not shown. > }, { lowerBound: Long("32"), count: Long("<num>") } ], sbeNumReads: [ { lowerBound: Long("0"), count: Long("<num>") }, { < Additional histogram groups not shown. > }, { lowerBound: Long("32768"), count: Long("<num>") } ] } }, queryFramework: { aggregate: { classicHybrid: Long("<num>"), classicOnly: Long("<num>"), cqf: Long("<num>"), sbeHybrid: Long("<num>"), sbeOnly: Long("<num>") }, find: { classic: Long("<num>"), cqf: Long("<num>"), sbe: Long("<num>") } } }, queryExecutor: { scanned : Long("<num>"), scannedObjects : Long("<num>"), collectionScans : { nonTailable : NumbeLong(<num>), total : Long("<num>") } }, record : { moves : Long("<num>") }, repl : { executor : { pool : { inProgressCount : <num> }, queues : { networkInProgress : <num>, sleepers : <num> }, unsignaledEvents : <num>, shuttingDown : <boolean>, networkInterface : <string> }, apply : { attemptsToBecomeSecondary : Long("<num>"), batches : { num : <num>, totalMillis : <num> }, ops : Long("<num>") }, buffer : { count : Long("<num>"), maxSizeBytes : Long("<num>"), sizeBytes : Long("<num>") }, initialSync : { completed : Long("<num>"), failedAttempts : Long("<num>"), failures : Long("<num>") }, network : { bytes : Long("<num>"), getmores : { num : <num>, totalMillis : <num> }, notPrimaryLegacyUnacknowledgedWrites : Long("<num>"), notPrimaryUnacknowledgedWrites : Long("<num>"), oplogGetMoresProcessed : { num : <num>, totalMillis : <num> }, ops : Long("<num>"), readersCreated : Long("<num>"), replSetUpdatePosition : { num : Long("<num>") } }, reconfig : { numAutoReconfigsForRemovalOfNewlyAddedFields : Long("<num>") }, stepDown : { userOperationsKilled : Long("<num>"), userOperationsRunning : Long("<num>") }, syncSource : { numSelections : Long("<num>"), numTimesChoseSame : Long("<num>"), numTimesChoseDifferent : Long("<num>"), numTimesCouldNotFind : Long("<num>") }, waiters : { opTime : Long("<num>"), replication : Long("<num>") } }, storage : { freelist : { search : { bucketExhausted : <num>, requests : <num>, scanned : <num> } } }, ttl : { deletedDocuments : Long("<num>"), passes : Long("<num>") } },
metrics
一个返回各种统计信息的文档,这些信息反映正在运行的
mongod
实例的当前使用情况和状态。
metrics.aggStageCounters
一个文档,其中报告聚合管道阶段的使用情况。
metrics.aggStageCounters
中的字段是聚合管道阶段的名称。对于每个管道阶段,serverStatus
报告该阶段的执行次数。已在版本 5.2(以及 5.0.6)中更新。
metrics.apiVersions
包含以下内容的文档:
每个客户端应用程序的名称
每个应用程序在过去 24 小时内配置的 Stable API 版本
查看
metrics.apiVersions
时请考虑以下事项:每个
appname
可能的返回值为:default
:该命令是在未指定 Stable API 版本的情况下发出的。1
:该命令是使用 Stable API 版本 1 发出的。
注意
可能会看到
appname
的两个返回值,因为可以在命令级别指定 Stable API 版本。某些命令可能是在没有 Stable API 版本的情况下发出的,而其他命令则是在版本 1 下发出的。API 版本指标保留 24 小时。如果过去 24 小时内没有使用具体 API 版本从应用程序发出命令,则将从指标中删除
appname
和 API 版本。这也适用于default
API 版本指标。连接至 MongoDB 实例时,通过在连接 URI 中指定
appname
来设置appname
。?appName=ZZZ
将appname
设置为ZZZZ
。访问 Stable API 的驱动程序可以设置默认
appname
。如果未配置
appname
,则根据产品自动填充默认值。例如,对于 URI 中没有appname
的 MongoDB Compass 连接,该指标返回:'MongoDB Compass': [ 'default' ]
。
版本 5.0 中的新增功能。
metrics.operatorCounters
一个文档,其中报告聚合管道操作符和表达式使用情况。
metrics.operatorCounters.expressions
带有数字的文档,指示表达式操作符的运行频率。
要获取特定操作符(例如大于操作符 (
$gt
))的指标,请将该操作符附加到命令中:db.runCommand( { serverStatus: 1 } ).metrics.operatorCounters.expressions.$gt 版本 5.0 中的新增功能。
metrics.operatorCounters.match
带有数字的文档,该数字指示匹配表达式运行的频率。
匹配表达式操作符也会作为聚合管道
$match
的一部分递增。如果$match
阶段使用$expr
操作符,则$expr
的计数器会递增,但组件计数器不会递增。考虑以下查询:
db.matchCount.aggregate( [ { $match: { $expr: { $gt: [ "$_id", 0 ] } } } ] ) 查询运行时,
$expr
的计数器会递增。$gt
的计数器不会递增。
metrics.changeStreams
报告大于 16 MB 的变更流事件的相关信息的文档。
5.0.19版本新增。
metrics.commands
报告数据库命令使用情况的文档。
metrics.commands
中的字段是数据库命令的名称。对于每个命令,serverStatus
都会报告执行的总次数和执行失败的次数。metrics.commands
包括replSetStepDownWithForce
(即带有force: true
的replSetStepDown
指令)和整个replSetStepDown
。在早期版本中,该命令仅报告整体replSetStepDown
指标。
metrics.commands.<command>.failed
<command>
在此mongod
上失败的次数。
metrics.commands.<create or collMod>.validator
对于
create
和collMod
命令,它是报告传递给命令的非空validator
对象的文档,用于指定集合的验证规则或表达式。
metrics.commands.<create or collMod>.validator.total
将非空
validator
对象作为选项传递给此mongod
上的命令的次数。
metrics.commands.<create or collMod>.validator.failed
由于模式验证错误,使用非空
validator
对象调用此mongod
上的命令失败的次数。
metrics.commands.<create or collMod>.validator.jsonSchema
将带有
$jsonSchema
的validator
对象作为选项传递给此mongod
上的命令的次数。
metrics.commands.<command>.total
在此
mongod
上执行<command>
的次数。
metrics.commands.update.pipeline
使用聚合管道更新此
mongod
上的文档的次数。从更新总数中减去该值以获得使用文档事务语法进行的更新次数。pipeline
计数器仅适用于update
和findAndModify
操作。
metrics.commands.findAndModify.pipeline
聚合管道中使用
findAndModify()
来更新此mongod
上的文档的次数。pipeline
计数器仅适用于update
和findAndModify
操作。
metrics.commands.update.arrayFilters
使用 arrayFilter 更新此
mongod
上的文档的次数。arrayFilters
计数器仅适用于update
和findAndModify
操作。
metrics.commands.findAndModify.arrayFilters
将 arrayFilter 与
findAndModify()
一起使用来更新此mongod
上的文档的次数。arrayFilters
计数器仅适用于update
和findAndModify
操作。
metrics.document
一个文档,其中反映文档访问权限和修改模式。将这些值与
opcounters
文档中的数据进行比较,后者跟踪操作总数。
metrics.dotsAndDollarsFields
带有数字的文档,该数字指示使用美元 (
$
) 前缀名称执行插入或更新操作的频率。此值不报告确切的操作次数。当 upsert 操作创建一个新文档时,它将被视为
insert
而不是update
。版本 5.0 中的新增功能。
metrics.getLastError
报告
getLastError
使用情况的文档。
metrics.getLastError.wtime
一个文档,其中报告
getLastError
w
参数大于1
的 操作计数。
metrics.getLastError.wtime.num
具有指定写关注
getLastError
即w
),等待副本集的一个或多个成员确认写入操作(即大于1
的w
值)。
metrics.getLastError.wtime.totalMillis
mongod
执行带写关注的getLastError
操作所花费的总时间(以毫秒为单位)(即w
),等待副本集的一个或多个成员确认写入操作(即大于1
的w
值)。
metrics.getLastError.wtimeouts
由于
wtimeout
阈值为getLastError
导致 写关注 操作超时的次数。对于默认和非默认写关注规范,该数字都会递增。
metrics.getLastError.default
一个文档,其中报告特定于使用默认写关注(即非
clientSupplied
写关注)的操作的getLastError
的使用情况。 默认写关注的可能来源是:implicitDefault
customDefault
getLastErrorDefaults
有关每种可能的写关注来源或
provenance
的信息,请参阅下表:来源说明clientSupplied
应用程序中指定了写关注。
customDefault
写入关注源自自定义的默认值。请参阅
setDefaultRWConcern
。getLastErrorDefaults
写关注源自副本集的
settings.getLastErrorDefaults
字段。implicitDefault
在没有所有其他写入关注规范的情况下,写入关注源自服务器。
metrics.mongos
包含有关
mongos
的指标的文档。
metrics.mongos.cursor
包含
mongos
使用的游标指标的文档。
metrics.mongos.cursor.moreThanOneBatch
自
mongos
启动以来返回多个批处理的游标的总数。其他批处理可使用getMore
命令进行检索。版本 5.0 中的新增功能。
metrics.mongos.cursor.totalOpened
自
mongos
启动以来已打开的游标总数,包括当前打开的游标。与metrics.cursor.open.total
不同,后者仅表示当前打开的游标数量。版本 5.0 中的新增功能。
metrics.queryExecutor.scanned
在查询和查询计划评估期间扫描的索引项目总数。该计数器与
explain()
的输出中的totalKeysExamined
相同。
metrics.queryExecutor.scannedObjects
查询和查询计划评估期间扫描的文档总数。该计数器与
explain()
的输出中的totalDocsExamined
相同。
metrics.queryExecutor.collectionScans.nonTailable
执行了集合扫描但未使用可追加游标的查询数量。
metrics.queryExecutor.collectionScans.total
执行集合扫描的查询总数。该总数包括使用和未使用可追加游标的查询。
metrics.repl
一个文档,其中报告与复制进程相关的指标。
metrics.repl
文档将出现在所有mongod
实例上,包括不属于副本集成员的实例。
metrics.repl.apply
一个文档,其中报告复制 oplog 中操作的应用情况。
metrics.repl.apply.batchSize
应用的 oplog 操作总数。
metrics.repl.apply.batchSize
随着批处理边界处的批处理中的操作数量而增加,而不是在每次操作之后递增。有关更详细的信息,请参阅
metrics.repl.apply.ops
。
metrics.repl.apply.batches
metrics.repl.apply.batches
报告副本集的从节点上的 oplog 应用程序进程。有关 oplog 应用程序进程的更多信息,请参阅多线程复制。
metrics.repl.apply.batches.totalMillis
mongod
应用 oplog 中的操作所花费的总时间(以毫秒为单位)。
metrics.repl.apply.ops
应用的 oplog 操作总数。每次操作后,
metrics.repl.apply.ops
都会递增。
metrics.repl.buffer
MongoDB 在批量应用 oplog 条目之前,会对复制同步源缓冲区中的 oplog 操作进行缓冲。
metrics.repl.buffer
提供了一种追踪 oplog 缓冲区的方法。有关 oplog 应用程序过程的更多信息,请参阅多线程复制。
metrics.repl.buffer.maxSizeBytes
缓冲区的大小上限。该值是
mongod
中的常量设置,不可配置。
metrics.repl.network
metrics.repl.network
报告复制过程的网络使用情况。
metrics.repl.network.bytes
metrics.repl.network.bytes
报告从复制同步源读取的总数据量。
metrics.repl.network.getmores
metrics.repl.network.getmores
报告getmore
操作的信息,这些操作是作为 oplog 复制进程的一部分从 oplog 游标请求其他结果。
metrics.repl.network.getmores.num
metrics.repl.network.getmores.num
报告getmore
操作的总数,这些操作是从复制同步源请求一组附加操作的操作。
metrics.repl.network.getmores.totalMillis
metrics.repl.network.getmores.totalMillis
报告从getmore
操作中收集数据所需的总时间。注意
此数字可能很大,因为,即使
getmore
操作没有初始返回数据,MongoDB 也会等待更多数据。
metrics.repl.network.getmores.numEmptyBatches
从节点从同步源接收的空
oplog
批处理的数量。如果从节点与源完全同步并且满足以下任一条件,则从节点会收到一个空批处理:getmore
在等待更多数据时超时,或者自从最后一次批处理发送到该从节点以来,同步源的大部分提交点已提前。
对于主节点,如果该实例以前是从节点,则该数字报告其作为从节点时收到的空批处理数。否则,对于主节点,此数字为
0
。
metrics.repl.network.notPrimaryLegacyUnacknowledgedWrites
由于当前
mongod
不处于PRIMARY
状态而失败的未确认 (w: 0
) 传统写入操作(请参阅 请求操作码 )的数量。
metrics.repl.network.oplogGetMoresProcessed.totalMillis
节点处理
getMore
命令所花费的时间(以毫秒为单位)计入metrics.repl.network.oplogGetMoresProcessed.num
。
metrics.repl.network.readersCreated
创建的 oplog 查询进程总数。每当连接发生错误时,包括超时或网络操作,MongoDB 都会创建新的 oplog 查询。此外,每次 MongoDB 选择新的复制源时,
metrics.repl.network.readersCreated
都会递增。
metrics.repl.network.replSetUpdatePosition.num
节点发送到其同步源的
replSetUpdatePosition
命令的数量。replSetUpdatePosition
命令是内部复制命令,用于将复制进度从节点传送到其同步源。注意
处于
STARTUP2
状态的副本集节点不会向其同步源发送replSetUpdatePosition
命令。
metrics.repl.reconfig
一个文档,其中包含节点的
newlyAdded
字段被主节点自动删除的次数。当一个节点首次被添加到副本集时,该节点的newlyAdded
字段将被设置为true
。版本 5.0 中的新增功能。
metrics.repl.reconfig.numAutoReconfigsForRemovalOfNewlyAddedFields
主节点自动删除的
newlyAdded
节点字段的次数。当一个节点首次被添加到副本集时,该节点的newlyAdded
字段将被设置为true
。在主节点收到指示节点状态为SECONDARY
、RECOVERING
或ROLLBACK
的节点心跳响应后,主节点将自动删除该节点的newlyAdded
字段。newlyAdded
字段存储在local.system.replset
集合中。版本 5.0 中的新增功能。
metrics.repl.stateTransition.lastStateTransition
报告的转换情况:
状态变更说明"stepUp"
节点升级成为主节点。
"stepDown"
节点降级成为从节点。
"rollback"
节点正在主动执行回滚。
""
节点未发生任何状态更改。
metrics.repl.stateTransition.userOperationsKilled
在
mongod
实例的状态变改期间停止的操作次数。注意
该指标反映被终止的操作总数,无论操作是由用户还是服务器发起。
metrics.repl.stateTransition.userOperationsRunning
在
mongod
实例的状态更改期间保持运行的操作数。注意
该指标反映正在运行的操作总数,无论操作是由用户还是服务器发起。
metrics.repl.syncSource
有关副本集节点的同步源选择进程的信息。
metrics.repl.syncSource.numSelections
节点尝试从可用同步源选项中选择节点进行同步的次数。例如,如果重新评估同步源或节点从当前同步源收到错误,则节点会尝试选择要从中进行同步的节点。
metrics.repl.waiters.replication
等待复制或日志写关注确认的线程数量。
5.0.27版本新增。
metrics.repl.waiters.opTime
排队等待本地复制 optime 分配的线程数。
5.0.27版本新增。
metrics.storage.freelist.search.bucketExhausted
mongod
在没有发现大量记录分配的情况下检查空闲列表的次数。
metrics.storage.freelist.search.requests
mongod
搜索可用记录分配的次数。
metrics.storage.freelist.search.scanned
mongod
搜索的可用记录分配的数量。
metrics.ttl
一个文档,其中报告 ttl 索引进程的资源使用情况的操作信息。
metrics.ttl.deletedDocuments
从具有 ttl 索引的集合中删除的文档总数。
metrics.ttl.passes
后台进程从具有 ttl 索引的集合中删除文档的次数。
metrics.cursor.moreThanOneBatch
自服务器进程启动以来返回多个批处理的游标总数。使用
getMore
命令可检索其他批处理。版本 5.0 中的新增功能。
metrics.cursor.totalOpened
自服务器进程启动以来已打开的游标总数,包括当前打开的游标。与
metrics.cursor.open.total
不同,后者仅表示当前打开的游标数量。版本 5.0 中的新增功能。
metrics.cursor.lifespan
一个文档,报告使用寿命位于指定时间段内的游标的数量。游标使用寿命是指从创建游标到使用
killCursors
命令终止游标或游标在批处理中没有剩余对象时的时间段。使用寿命时间段为:
< 1 秒
>= 1 秒但 < 5 秒
>= 5 秒但 < 15 秒
>= 15 秒但 < 30 秒
>= 30 秒但 < 1 分钟
>= 1 分钟但 < 10 分钟
>= 10 分钟
版本 5.0 中的新增功能。
metrics.cursor.open.noTimeout
打开游标的数量,设置了选项
DBQuery.Option.noTimeout
,防止一段时间不活动后出现超时。
metrics.cursor.open.total
MongoDB 为客户端维护的游标数量。由于 MongoDB 会耗尽未使用的游标,因此该值通常很小或为零。但是,如果存在队列、过时的可追加游标或大量操作,则该值可能会增加。
metrics.cursor.open.singleTarget
仅针对单个分片的游标总数。仅
mongos
实例报告metrics.cursor.open.singleTarget
值。
metrics.cursor.open.multiTarget
仅针对多个分片的游标的总数。仅
mongos
实例报告metrics.cursor.open.multiTarget
值。
镜像读 (Mirrored Reads)
仅在 mongod 上可用。
"mirroredReads" : { "seen" : <num>, "sent" : <num> },
mirroredReads
仅在 mongod 上可用。
报告镜像读情况的文档。如要返回
mirroredReads
信息,必须明确指定包含的内容:db.runCommand( { serverStatus: 1, mirroredReads: 1 } ) mirroredReads.seen
该节点收到的支持镜像的操作的数量。
网络
network : { bytesIn : Long("<num>"), bytesOut : Long("<num>"), physicalBytesIn : Long("<num>"), physicalBytesOut : Long("<num>"), numSlowDNSOperations : Long("<num>"), numSlowSSLOperations : Long("<num>"), numRequests : Long("<num>"), tcpFastOpen : { kernelSetting : Long("<num>"), serverSupported : <bool>, clientSupported : <bool>, accepted : Long("<num>") }, compression : { snappy : { compressor : { bytesIn : Long("<num>"), bytesOut : Long("<num>") }, decompressor : { bytesIn : Long("<num>"), bytesOut : Long("<num>") } }, zstd : { compressor : { bytesIn : Long("<num>"), bytesOut : Long("<num>") }, decompressor : { bytesIn : Long("<num>"), bytesOut : Long("<num>") } }, zlib : { compressor : { bytesIn : Long("<num>"), bytesOut : Long("<num>") }, decompressor : { bytesIn : Long("<num>"), bytesOut : Long("<num>") } } }, serviceExecutors : { passthrough : { threadsRunning : <num>, clientsInTotal : <num>, clientsRunning : <num>, clientsWaitingForData : <num> }, fixed : { threadsRunning : <num>, clientsInTotal : <num>, clientsRunning : <num>, clientsWaitingForData : <num> } } },
network
报告 MongoDB 网络使用相关数据的文档。这些统计信息仅衡量入口连接,特别是
mongod
或mongos
通过客户端或其他mongod
或mongos
实例发起的网络连接看到的流量。由该mongod
或mongos
实例启动的网络连接(特别是出口连接)产生的流量值不 包含在这些统计信息中。
network.numRequests
服务器收到的不同请求总数。使用此值为
network.bytesIn
和network.bytesOut
值提供上下文,确保 MongoDB 的网络利用率与预期和应用程序使用情况一致。
network.tcpFastOpen.kernelSetting
仅 Linux
返回
/proc/sys/net/ipv4/tcp_fastopen
的值:0
- 系统已禁用 TCP 快速打开。1
- 为传出连接启用 TCP 快速打开。2
- 为传入连接启用 TCP 快速打开。3
- 为传入和传出连接启用“TCP 快速打开”。
network.tcpFastOpen.serverSupported
如果主机操作系统支持入站 TCP 快速打开 (TFO) 连接,则返回
true
。如果主机操作系统不 支持入站 TCP 快速打开 (TFO) 连接,则返回
false
。
network.tcpFastOpen.clientSupported
如果主机操作系统支持出站 TCP 快速打开 (TFO) 连接,则返回
true
。如果主机操作系统不支持出站 TCP 快速打开 (TFO) 连接,则返回
false
。
network.compression.snappy
一个文档,返回有关使用 snappy 库压缩和解压缩的字节数的统计信息。
network.compression.zstd
一个文档,返回有关使用 zstd 库压缩和解压缩的字节数的统计信息。
network.compression.zlib
一个文档,返回有关使用 zlib 库压缩和解压缩的字节数的统计信息。
network.serviceExecutors.passthrough
版本 5.0 中的新增功能。
一个文档,报告有关
passthrough
服务执行程序的线程和客户端的数据。passthrough
服务执行程序为每个客户端创建一个新线程,并在客户端结束后销毁该线程。
network.serviceExecutors.passthrough.clientsInTotal
版本 5.0 中的新增功能。
分配给
passthrough
服务执行程序的客户端总数。可以将客户端分配给passthrough
服务执行程序和当前未运行的请求。
network.serviceExecutors.passthrough.clientsWaitingForData
版本 5.0 中的新增功能。
使用等待来自网络的传入数据的
passthrough
服务执行程序的客户端数量。
network.serviceExecutors.fixed
版本 5.0 中的新增功能。
一个文档,报告有关
fixed
服务执行程序的线程和客户端的数据。fixed
服务执行程序拥有固定数量的线程。线程被临时分配给客户端,并在客户端结束后予以保留。
opLatencies
仅适用于 ``mongod`` 实例
opLatencies : { reads : <document>, writes : <document>, commands : <document> },
opLatencies
一个文档,其中包含整个实例的操作延迟。有关此文档的说明,请参阅
latencyStats
文档。只有
mongod
实例报告opLatencies
。
opReadConcernCounters
仅适用于 mongod 实例
opReadConcernCounters : { available : Long("<num>"), linearizable : Long("<num>"), local : Long("<num>"), majority : Long("<num>"), snapshot : Long("<num>"), none : Long("<num>") }
opReadConcernCounters
已在版本 5.0 中删除。已被替换为
readConcernCounters
。一个文档,其中报告自
mongod
实例上次启动以来,查询操作为该实例指定的读关注级别。指定w
说明"available"
指定读关注级别
"available"
的查询操作的数量。"linearizable"
指定读关注级别
"linearizable"
的查询操作的数量。"local"
指定读关注级别
"local"
的查询操作的数量。"majority"
指定读关注级别
"majority"
的查询操作的数量。"snapshot"
指定读关注级别
"snapshot"
的查询操作的数量。"none"
未指定读关注级别而是使用默认读关注级别的查询操作数量。
opWriteConcernCounters
仅适用于 mongod 实例
opWriteConcernCounters : { insert : { wmajority : Long("<num>"), wnum : { <num> : Long("<num>"), ... }, wtag : { <tag1> : Long("<num>"), ... }, none : Long("<num>"), noneInfo : { CWWC : { wmajority : Long("<num>"), wnum : { <num> : Long("<num>"), ... }, wtag : { <tag1> : Long("<num>"), ... } }, implicitDefault : { wmajority : Long("<num>") wnum : { <num> : Long("<num>"), ... } } } }, update : { wmajority : Long("<num>"), wnum : { <num> : Long("<num>"), ... }, wtag : { <tag1> : Long("<num>"), ... }, none : Long("<num>"), noneInfo : { CWWC : { wmajority : Long("<num>"), wnum : { <num> : Long("<num>"), ... } wtag : { <tag1> : Long("<num>"), ... } }, implicitDefault : { wmajority : Long("<num>") wnum : { <num> : Long("<num>"), ... } } } }, delete : { wmajority : Long("<num>") wnum : { <num> : Long("<num>"), ... }, wtag : { <tag1> : Long("<num>"), ... }, none : Long("<num>"), noneInfo : { CWWC : { wmajority : Long("<num>"), wnum : { <num> : Long("<num>"), ... }, wtag : { <tag1> : Long("<num>"), ... } }, implicitDefault : { wmajority : Long("<num>") wnum : { <num> : Long("<num>"), ... } } } } }
opWriteConcernCounters
一个文档,其中报告自
mongod
实例上次启动以来,写入操作为该实例指定的写关注。更具体地说,
opWriteConcernCounters
报告写操作指定的 w:<value>。写关注的日志标志选项 (j
) 和超时选项 (wtimeout
) 不影响计数。即使操作超时,计数也会递增。注意
仅当
reportOpWriteConcernCountersInServerStatus
参数设置为true
(默认为false
)时才可用。
opWriteConcernCounters.insert
一个文档,其中报告自
mongod
实例上次启动以来,插入操作为该实例指定的 w: <value>:注意
仅当
reportOpWriteConcernCountersInServerStatus
参数设置为true
(默认为false
)时才可用。insert : { wmajority : Long("<num>"), wnum : { <num> : Long("<num>"), ... }, wtag : { <tag1> : Long("<num>"), ... }, none : Long("<num>"), noneInfo : { CWWC : { wmajority : Long("<num>"), wnum : {}, wtag : {} }, implicitDefault : { wmajority : Long("<num>") wnum : {} } } }, 指定w
说明"wmajority"
指定
w: "majority"
的插入操作次数。"wnum"
指定
w: <num>
的插入操作次数。计数按特定的 ``<num>`` 进行分组。"wtag"
指定
w: <tag>
的插入操作次数。计数按特定<tag>
分组。"none"
未指定
w
值的插入操作数。这些操作使用1
的默认值w
。"noneInfo"
使用默认写关注的非事务查询操作的数量。这些指标跟踪
cluster wide write concern
(全局默认写关注)和隐式默认写关注的使用情况。opWriteConcernCounters.noneInfo
中的值之和应等于opWriteConcernCounters.none
的值。
opWriteConcernCounters.update
一个文档,其中报告自
mongod
实例上次启动以来,更新操作为该实例指定的 w: <value>:注意
仅当
reportOpWriteConcernCountersInServerStatus
参数设置为true
(默认为false
)时才可用。update : { wmajority : Long("<num>"), wnum : { <num> : Long("<num>"), ... }, wtag : { <tag1> : Long("<num>"), ... }, none : Long("<num>"), noneInfo : { CWWC : { wmajority : Long("<num>"), wnum : {}, wtag : {} }, implicitDefault : { wmajority : Long("<num>") wnum : {} } } }, 指定w
说明"wmajority"
指定
w: "majority"
的更新操作数。"wnum"
指定
w: <num>
的更新操作数。计数按特定<num>
分组。"wtag"
指定
w: <tag>
的更新操作数。计数按特定<tag>
分组。"none"
未指定
w
值的更新操作数。这些操作使用1
的默认值w
。"noneInfo"
使用默认写关注的非事务查询操作的数量。这些指标跟踪
cluster wide write concern
(全局默认写关注)和隐式默认写关注的使用情况。opWriteConcernCounters.noneInfo
中的值之和应等于opWriteConcernCounters.none
的值。
opWriteConcernCounters.delete
一个文档,其中报告自
mongod
实例上次启动以来,删除操作为该实例指定的 w: <value>:注意
仅当
reportOpWriteConcernCountersInServerStatus
参数设置为true
(默认为false
)时才可用。delete : { wmajority : Long("<num>"), wnum : { <num> : Long("<num>"), ... }, wtag : { <tag1> : Long("<num>"), ... }, none : Long("<num>"), noneInfo : { CWWC : { wmajority : Long("<num>"), wnum : {}, wtag : {} }, implicitDefault : { wmajority : Long("<num>") wnum : {} } } } 指定w
说明"wmajority"
指定
w: "majority"
的删除操作数量。"wnum"
指定
w: <num>
的删除操作数量。计数按特定<num>
分组。"wtag"
指定
w: <tag>
的删除操作数量。计数按特定<tag>
分组。"none"
未指定
w
值的删除操作数量。这些操作使用1
的默认值w
。"noneInfo"
使用默认写关注的非事务查询操作的数量。这些指标跟踪
cluster wide write concern
(全局默认写关注)和隐式默认写关注的使用情况。opWriteConcernCounters.noneInfo
中的值之和应等于opWriteConcernCounters.none
的值。
运算计数器
返回的操作计数器。* 值的类型为 NumberLong。
opcounters : { insert : Long("<num>"), query : Long("<num>"), update : Long("<num>"), delete : Long("<num>"), getmore : Long("<num>"), command : Long("<num>"), },
opcounters
一个文档,其中按类型报告自
mongod
实例上次启动以来的数据库操作。这些数字将随着时间的推移而增长,直到下一次重新启动。随时间推移分析这些值,跟踪数据库的使用情况。
注意
opcounters
中的数据将影响多个文档的操作(如批量插入或多重更新操作)视为单个操作。有关更细粒度的文档级操作跟踪,请参阅metrics.document
。此外,这些值还反映接收到的操作,即使操作不成功,也会递增。
opcounters.insert
自
mongod
实例上次启动以来收到的插入操作总数。返回的操作计数器。* 值的类型为 NumberLong。
opcounters.query
自
mongod
实例上次启动以来收到的查询总数。返回的操作计数器。* 值的类型为 NumberLong。
opcounters.update
自
mongod
实例上次启动以来收到的更新操作总数。返回的操作计数器。* 值的类型为 NumberLong。
opcounters.delete
自
mongod
实例上次启动以来的删除操作总数。返回的操作计数器。* 值的类型为 NumberLong。
opcounters.getmore
自
mongod
实例上次启动以来getMore
操作的总数。即使查询计数较低,此计数器读数也可能很高。从节点发送getMore
操作,作为复制进程的一部分。返回的操作计数器。* 值的类型为 NumberLong。
opcounters.command
自
mongod
实例上次启动以来向数据库发出的命令总数。opcounters.command
计算 除 写入命令之外的所有 命令insert
: 、update
和delete
。返回的操作计数器。* 值的类型为 NumberLong。
opcounters.deprecated
仅当使用已弃用操作码时,此部分才会出现在
db.serverStatus()
输出中。deprecated: { opQuery: Long("<num>"), opGetMore: Long("<num>"), opKillCursors: Long("<num>"), opDelete: Long("<num>"), opUpdate: Long("<num>"), opInsert: Long("<num>"), total: Long("<num>") } 这些操作码在MongoDB 5.0中已弃用,并且MongoDB 5.1中已删除对这些操作码的支持。 从MongoDB 5.1开始,
mongod
拒绝使用已弃用操作码的请求,但会继续递增相应的计数器。OP_QUERY
是一般规则的例外。mongod
继续支持使用OP_QUERY
的 hello 和 isMaster 请求。mongod
拒绝任何其他OP_QUERY
请求。
opcountersRepl
返回的 opcountersRepl。*值的类型为 NumberLong。
opcountersRepl : { insert : Long("<num>"), query : Long("<num>"), update : Long("<num>"), delete : Long("<num>"), getmore : Long("<num>"), command : Long("<num>"), },
opcountersRepl
一个文档,其中按类型报告自
mongod
实例上次启动以来的数据库复制操作。这些值只有在当前主机是副本集成员时才会出现。
由于 MongoDB 在复制过程中对操作进行序列化的方式不同,这些值与
opcounters
值不同。有关复制的更多信息,请参阅复制。这些数字将随时间推移而增长,以响应数据库的使用,直到下次重新启动。随时间推移分析这些值,跟踪数据库的使用情况。
返回的 opcountersRepl。*值的类型为 NumberLong。
opcountersRepl.insert
自
mongod
实例上次启动以来复制的插入操作总数。返回的 opcountersRepl。*值的类型为 NumberLong。
opcountersRepl.query
自
mongod
实例上次启动以来复制的查询总数。返回的 opcountersRepl。*值的类型为 NumberLong。
opcountersRepl.update
自
mongod
实例上次启动以来复制的更新操作总数。返回的 opcountersRepl。*值的类型为 NumberLong。
opcountersRepl.delete
自
mongod
实例上次启动以来复制的删除操作总数。返回的 opcountersRepl。*值的类型为 NumberLong。
opcountersRepl.getmore
自
mongod
实例上次启动以来getMore
操作的总数。即使查询计数较低,此计数器读数也可能很高。从节点发送getMore
操作,作为复制进程的一部分。返回的 opcountersRepl。*值的类型为 NumberLong。
opcountersRepl.command
自
mongod
实例上次启动以来向数据库发出的已复制命令总数。返回的 opcountersRepl。*值的类型为 NumberLong。
oplogTruncation
oplogTruncation : { totalTimeProcessingMicros : Long("<num>"), processingMethod : <string>, oplogMinRetentionHours : <double> totalTimeTruncatingMicros : Long("<num>"), truncateCount : Long("<num>") },
oplogTruncation
一个文档,其中报告 oplog 截断情况。
该字段仅在当前实例是副本集节点并且使用 WiredTiger 存储引擎或适用于自管理部署的内存存储引擎时出现。
可用于 WiredTiger 存储引擎。
oplogTruncation.totalTimeProcessingMicros
扫描或采样 oplog 以确定 oplog 截断点所用的总时间(以微秒为单位)。
totalTimeProcessingMicros
仅在mongod
实例在现有数据文件上启动时才有意义(即对用于自管理部署的内存存储引擎没有意义)。看
oplogTruncation.processingMethod
可用于 WiredTiger 存储引擎。
oplogTruncation.processingMethod
启动时用于确定 oplog 截断点的方法。该值可以是
"sampling"
或"scanning"
。processingMethod
仅在mongod
实例在现有数据文件上启动时才有意义(即对用于自管理部署的内存存储引擎没有意义)。可用于 WiredTiger 存储引擎。
oplogTruncation.oplogMinRetentionHours
Oplog 的最短保留期(以小时为单位)。如果 oplog 已超过 oplog 大小,则
mongod
仅截断早于已配置保留值的 oplog 条目。仅当
mongod
是副本集的节点且 满足以下条件时才可见:mongod
是使用--oplogMinRetentionHours
命令行选项或storage.oplogMinRetentionHours
配置文件选项启动的,or
最短保留期是在启动后使用
replSetResizeOplog
配置的。
oplogTruncation.totalTimeTruncatingMicros
执行 oplog 截断所花费的累积时间,以微秒为单位。
可用于 WiredTiger 存储引擎。
oplogTruncation.truncateCount
oplog 截断的累积次数。
可用于 WiredTiger 存储引擎。
readConcernCounters
版本 5.0 中的新增功能。
readConcernCounters : { nonTransactionOps : { none : Long("<num>"), noneInfo : { CWRC : { local : Long("<num>"), available : Long("<num>"), majority : Long("<num>") }, implicitDefault : { local : Long("<num>"), available : Long("<num>") } }, local : Long("<num>"), available : Long("<num>"), majority : Long("<num>"), snapshot : { withClusterTime : Long("<num>"), withoutClusterTime : Long("<num>") }, linearizable : Long("<num>") }, transactionOps : { none : Long("<num>"), noneInfo : { CWRC : { local : Long("<num>"), available : Long("<num>"), majority : Long("<num>") }, implicitDefault : { local : Long("<num>"), available : Long("<num>") } }, local : Long("<num>"), majority : Long("<num>"), snapshot : { withClusterTime : Long("<num>"), withoutClusterTime : Long("<num>") } } },
readConcernCounters
用于报告查询操作指定的读关注级别的文档。该文档包含
readConcernCounters.nonTransactionOps
和readConcernCounters.transactionOps
文档。
readConcernCounters.nonTransactionOps
一个文档,其中报告数据库服务器上次启动后执行的非事务查询操作所指定的读关注级别。
readConcernCounters.nonTransactionOps.none
未指定读关注级别而使用以下任一选项的非事务查询操作数量:
默认的读关注级别,或
全局默认读取会关注配置(如果由
setDefaultRWConcern
命令设置)。
readConcernCounters.nonTransactionOps.noneInfo
使用全局默认读关注和隐式默认读关注的非事务查询操作的数量。
readConcernCounters.nonTransactionOps.noneInfo
中的值之和应等于readConcernCounters.nonTransactionOps.none
的值。
readConcernCounters.nonTransactionOps.local
指定
"local"
读关注级别的非事务查询操作的数量。
readConcernCounters.nonTransactionOps.available
指定
"available"
读关注级别的非事务查询操作的数量。
readConcernCounters.nonTransactionOps.majority
指定
"majority"
读关注级别的非事务查询操作的数量。
readConcernCounters.nonTransactionOps.snapshot
包含指定
"snapshot"
读关注级别的非事务查询操作的文档。
readConcernCounters.nonTransactionOps.snapshot.withClusterTime
指定
"snapshot"
读关注级别和集群时间(指定时间点)的非事务查询操作数。
readConcernCounters.nonTransactionOps.snapshot.withoutClusterTime
指定
"snapshot"
读关注级别但没有集群时间的非事务查询操作数,这意味着省略了某个时间点,服务器将读取该节点可用的最近提交的快照。
readConcernCounters.nonTransactionOps.linearizable
指定
"linearizable"
读关注级别的非事务查询操作的数量。
readConcernCounters.transactionOps
一个文档,其中报告数据库服务器上次启动后执行的事务查询操作所指定的读关注级别。
readConcernCounters.transactionOps.none
满足以下条件的事务查询操作数:未指定读关注级别而是使用默认读关注级别或借助
setDefaultRWConcern
命令添加的全局默认读关注或写关注配置。
readConcernCounters.transactionOps.local
指定
"local"
读关注级别的事务查询操作数。
readConcernCounters.transactionOps.available
指定
"available"
读关注级别的事务查询操作数。
readConcernCounters.transactionOps.majority
指定
"majority"
读关注级别的事务查询操作数。
readConcernCounters.transactionOps.snapshot
包含指定
"snapshot"
读关注级别的事务查询操作的文档。
readConcernCounters.transactionOps.snapshot.withClusterTime
指定
"snapshot"
读关注级别和集群时间(指定时间点)的事务查询操作数。
readConcernCounters.transactionOps.snapshot.withoutClusterTime
指定
"snapshot"
读关注级别但没有集群时间的事务查询操作数,这意味着省略了某个时间点,服务器将读取该节点可用的最近提交的快照。
repl
repl : { hosts : [ <string>, <string>, <string> ], setName : <string>, setVersion : <num>, isWritablePrimary : <boolean>, secondary : <boolean>, primary : <hostname>, me : <hostname>, electionId : ObjectId(""), primaryOnlyServices: { ReshardingRecipientService: { state: <string>, numInstances: <num> }, RenameCollectionParticipantService: { state: <string>, numInstances: <num> }, ShardingDDLCoordinator: { state: <string>, numInstances: <num> }, ReshardingDonorService: { state: <string>, numInstances: <num> } }, rbid : <num>, replicationProgress : [ { rid : <ObjectId>, optime : { ts: <timestamp>, term: <num> }, host : <hostname>, memberId : <num> }, ... ] }
repl.setName
一个体现当前副本集名称的字符串。该值反映了
--replSet
命令行参数或配置文件中的replSetName
值。
repl.isWritablePrimary
一个布尔值,指示当前节点是否为副本集的主节点。
repl.secondary
一个布尔值,指示当前节点是否为副本集的从节点。
repl.primary
副本集当前主节点的主机名和端口信息 (
"host:port"
)。
repl.primaryOnlyServices
包含服务器上每个活动主服务实例的数量和状态的文档。主服务只能在服务器为主服务器时启动,但可以在服务器更改状态后继续运行直至完成。
版本 5.0 中的新增功能。
repl.primaryOnlyServices.ReshardingRecipientService
包含
ReshardingRecipientService
的状态和实例数量的文档:由分片接收,根据新的分片键和区域,分片会在重新分片操作后拥有数据块。
重新分片协调节点指示每个发送和接收分片主节点,以重命名临时分片集合。临时集合将成为新的重新分片集合。
版本 5.0 中的新增功能。
repl.primaryOnlyServices.RenameCollectionParticipantService
包含
RenameCollectionParticipantService
的状态和实例数量的文档:RenameCollectionParticipantService
确保在某个分片收到 renameCollection 请求后,该分片能够在系统出现故障的情况下恢复本地重命名。版本 5.0 中的新增功能。
repl.primaryOnlyServices.ShardingDDLCoordinator
包含
ShardingDDLCoordinator
的状态和实例数量的文档:ShardingDDLCoordinator
服务管理主节点数据库的 DDL 操作,例如:创建数据库、删除数据库、renameCollection。ShardingDDLCoordinator
确保在分片集群内的任何一个特定时间点,对每个数据库都执行一次 (DDL) 操作。版本 5.0 中的新增功能。
repl.primaryOnlyServices.ReshardingDonorService
包含
ReshardingDonorService
的状态和实例数量的文档:捐赠者是在重命名操作完成之前拥有分片集合数据段的分片。
重新分片协调节点指示每个发送和接收分片主节点,以重命名临时分片集合。临时集合将成为新的重新分片集合。
版本 5.0 中的新增功能。
repl.replicationProgress
数组,其中副本集的每个成员都有一个文档,用于向该成员报告复制进程。通常,这是主节点,如果使用链式复制,则为从节点。
要包含此输出,必须将
repl
选项传递给serverStatus
,如下所示:db.serverStatus({ "repl": 1 }) db.runCommand({ "serverStatus": 1, "repl": 1 }) repl.replicationProgress
部分的内容取决于每个节点的复制源。本部分支持内部操作,仅供内部和诊断使用。
repl.replicationProgress[n].optime
该节点报告的有关该节点应用 oplog 中最后一次操作的信息。
安全性
security : { authentication : { saslSupportedMechsReceived : <num>, mechanisms : { MONGODB-X509 : { speculativeAuthenticate : { received : Long("<num>"), successful : Long("<num>") }, authenticate : { received : Long("<num>"), successful : Long("<num>") } }, SCRAM-SHA-1 : { speculativeAuthenticate : { received : Long("<num>"), successful : Long("<num>") }, authenticate : { received : Long("<num>"), successful : Long("<num>") } }, SCRAM-SHA-256 : { speculativeAuthenticate : { received : Long("<num>"), successful : Long("<num>") }, authenticate : { received : Long("<num>"), successful : Long("<num>") } } } }, SSLServerSubjectName: <string>, SSLServerHasCertificateAuthority: <boolean>, SSLServerCertificateExpirationDate: <date> },
security
一个文档,其中报告:
security.authentication.saslSupportedMechsReceived
版本 5.0 中的新增功能。
hello
请求包含有效hello.saslSupportedMechs
字段的次数。
security.authentication.mechanisms
一个文档,其中报告使用给定身份验证机制对
mongod
或mongos
实例进行身份验证的次数。文档中的值区分标准身份验证和推测性身份验证。[1]注意
mechanisms
文档中的字段取决于authenticationMechanisms
参数的配置。mechanisms
文档包含mongod
或mongos
实例支持的每种身份验证机制的字段。以下示例展示了仅支持 x.509 身份验证的部署的
mechanisms
文档的形状。
security.authentication.mechanisms.MONGODB-X509
一个文档,其中报告使用 x.509 对
mongod
或mongos
实例进行身份验证的次数。包括
x.509
身份验证尝试总次数以及推测性尝试子集。[1]
security.authentication.mechanisms.MONGODB-X509.speculativeAuthenticate.successful
使用 x.509 成功收到的推测性身份验证尝试次数。[1]
security.authentication.mechanisms.MONGODB-X509.authenticate.received
使用 x.509 收到的成功和失败的身份验证尝试次数。此值包括使用 x.509 收到的推测性身份验证尝试。
security.authentication.mechanisms.MONGODB-X509.authenticate.successful
使用 x.508 收到的成功身份验证尝试次数。此值包括使用 x.509 的成功推测性身份验证尝试。
[1] (1, 2, 3, 4) 推测性身份验证可最大限度地减少身份验证过程中的网络往返次数,从而优化性能。
分片
{ configsvrConnectionString : 'csRS/cfg1.example.net:27019,cfg2.example.net:27019,cfg2.example.net:27019', lastSeenConfigServerOpTime : { ts : <timestamp>, t : Long("<num>") }, maxChunkSizeInBytes : Long("<num>") }
sharding
包含与分片集群相关的数据的文档。
lastSeenConfigServerOpTime
仅适用于mongos
或分片成员,不适用于配置服务器。
sharding.lastSeenConfigServerOpTime
mongos
或分片节点已看到的 CSRS 主节点的最新 optime。optime 文档包括:仅当分片集群使用 CSRS 时,才会出现
lastSeenConfigServerOpTime
。
sharding.maxChunkSizeInBytes
版本 3.6 中的新增功能。
数据段的最大大小限制。 如果最近已在配置服务器上更新数据段大小,则
maxChunkSizeInBytes
可能不会反映最新值。
shardingStatistics
在分片的成员上运行时:
shardingStatistics : { countStaleConfigErrors : Long("<num>"), countDonorMoveChunkStarted : Long("<num>"), countDonorMoveChunkCommitted : Long("<num>"), countDonorMoveChunkAborted : Long("<num>"), totalDonorMoveChunkTimeMillis : Long("<num>"), totalDonorChunkCloneTimeMillis : Long("<num>"), totalCriticalSectionCommitTimeMillis : Long("<num>"), totalCriticalSectionTimeMillis : Long("<num>"), countDocsClonedOnRecipient : Long("<num>"), countBytesClonedOnRecipient : Long("<num>"), countDocsClonedOnCatchUpOnRecipient : Long("<num>"), countBytesClonedOnCatchUpOnRecipient : Long("<num>"), countDocsClonedOnDonor : Long("<num>"), countRecipientMoveChunkStarted : Long("<num>"), countDocsDeletedByRangeDeleter : Long("<num>"), countDonorMoveChunkLockTimeout : Long("<num>"), unfinishedMigrationFromPreviousPrimary : Long("<num>"), catalogCache : { numDatabaseEntries : Long("<num>"), numCollectionEntries : Long("<num>"), countStaleConfigErrors : Long("<num>"), totalRefreshWaitTimeMicros : Long("<num>"), numActiveIncrementalRefreshes : Long("<num>"), countIncrementalRefreshesStarted : Long("<num>"), numActiveFullRefreshes : Long("<num>"), countFullRefreshesStarted : Long("<num>"), countFailedRefreshes : Long("<num>") }, rangeDeleterTasks : <num>, resharding : { countReshardingOperations : Long("<num>"), countReshardingSuccessful : Long("<num>"), countReshardingFailures : Long("<num>"), countReshardingCanceled : Long("<num>"), totalOperationTimeElapsedMillis : Long("<num>"), remainingOperationTimeEstimatedMillis : Long("<num>"), approxDocumentsToCopy : Long("<num>"), documentsCopied : Long("<num>"), approxBytesToCopy : Long("<num>"), bytesCopied : Long("<num>"), totalCopyTimeElapsedMillis : Long("<num>"), oplogEntriesFetched : Long("<num>"), oplogEntriesApplied : Long("<num>"), totalApplyTimeElapsedMillis : Long("<num>"), countWritesDuringCriticalSection : Long("<num>"), totalCriticalSectionTimeElapsedMillis : Long("<num>"), donorState : <num>, recipientState : <num>, coordinatorState : <num>, opStatus : <num>, lastOpEndingChunkImbalance: Long("<num>") } },
shardingStatistics : { numHostsTargeted: { find : { allShards: Long("<num>"), manyShards: Long("<num>"), oneShard: Long("<num>"), unsharded: Long("<num>") }, insert: { allShards: Long("<num>"), manyShards: Long("<num>"), oneShard: Long("<num>"), unsharded: Long("<num>") }, update: { allShards: Long("<num>"), manyShards: Long("<num>"), oneShard: Long("<num>"), unsharded: Long("<num>") }, delete: { allShards: Long("<num>"), manyShards: Long("<num>"), oneShard: Long("<num>"), unsharded: Long("<num>") }, aggregate: { allShards: Long("<num>"), manyShards: Long("<num>"), oneShard: Long("<num>"), unsharded: Long("<num>") } } }, catalogCache : { numDatabaseEntries : Long("<num>"), numCollectionEntries : Long("<num>"), countStaleConfigErrors : Long("<num>"), totalRefreshWaitTimeMicros : Long("<num>"), numActiveIncrementalRefreshes : Long("<num>"), countIncrementalRefreshesStarted : Long("<num>"), numActiveFullRefreshes : Long("<num>"), countFullRefreshesStarted : Long("<num>"), countFailedRefreshes : Long("<num>") } }
"shardingStatistics" : { "numShardedCollections" : Long(<num>) }
shardingStatistics.countStaleConfigErrors
线程遇到过时配置异常的总次数。由于过时配置异常会触发元数据刷新,因此该数字大致与元数据刷新次数成正比。
仅当在分片上运行时才出现。
shardingStatistics.countDonorMoveChunkStarted
作为数据 迁移进程数据块 的一部分, MongoDB在分片的主节点
moveChunk
(primary node in the replica set)节点上启动 命令的总次数。这个不断增加的数字不考虑数据数据块迁移是否成功。仅当在分片上运行时才出现。
shardingStatistics.countDonorMoveChunkCommitted
MongoDB 在分片主节点上提交的数据段迁移总数。
仅在分片上可用。
从 MongoDB 5.0.18开始提供。
shardingStatistics.countDonorMoveChunkAborted
MongoDB 在分片主节点上中止的数据段迁移总数。
仅在分片上可用。
从 MongoDB 5.0.18开始提供。
shardingStatistics.totalDonorMoveChunkTimeMillis
将数据段从当前分片移动到另一个分片的累积时间(以毫秒为单位)。 对于每个数据段迁移,时间从
moveChunk
命令启动时开始,到在数据段迁移过程中将数据段移动到另一个分片时结束。仅在分片上可用。
从 MongoDB 5.0.18开始提供。
shardingStatistics.totalDonorChunkCloneTimeMillis
数据段数据块的克隆阶段在分片的主节点 (primary node in the replica set)节点上花费的分片时间(以毫秒为单位)。 具体来说,对于该分片上的分片迁移,跟踪的时间从
moveChunk
命令开始,到目标分分片进入catchup
阶段以应用数据段数据块期间发生的更改之前结束。仅当在分片上运行时才出现。
shardingStatistics.totalCriticalSectionCommitTimeMillis
数据段迁移的更新元数据阶段在分片的主节点上花费的累积时间(以毫秒为单位)。 在更新元数据阶段,MongoDB 会阻止对集合的所有操作。
仅当在分片上运行时才出现。
shardingStatistics.totalCriticalSectionTimeMillis
数据段迁移的追赶阶段和更新元数据阶段在分片主节点上花费的累积时间(以毫秒为单位)。
要计算追赶阶段的持续时间,请从
totalCriticalSectionTimeMillis
中减去totalCriticalSectionCommitTimeMillis
:totalCriticalSectionTimeMillis - totalCriticalSectionCommitTimeMillis 仅当在分片上运行时才出现。
shardingStatistics.countBytesClonedOnRecipient
在数据段迁移过程中,MongoDB 在接收分片的主节点上克隆的累计字节数。
有关数据同步的详细信息,请参阅副本集数据同步。
仅在分片上可用。
从 MongoDB 5.0.18开始提供。
shardingStatistics.countDocsClonedOnCatchUpOnRecipient
在数据段迁移过程的追赶阶段,MongoDB 在接收分片的主节点上克隆的累计文档数。
有关数据同步的详细信息,请参阅副本集数据同步。
仅在分片上可用。
从 MongoDB 5.0.18开始提供。
shardingStatistics.countBytesClonedOnCatchUpOnRecipient
在数据段迁移过程的追赶阶段,MongoDB 在接收分片的主节点上克隆的累计字节数。
有关数据同步的详细信息,请参阅副本集数据同步。
仅在分片上可用。
从 MongoDB 5.0.18开始提供。
shardingStatistics.countRecipientMoveChunkStarted
此成员作为接收分片的主分片,已开始接收的数据段的累计数量(无论移动是否成功),该计数会持续增加。
仅当在分片上运行时才出现。
shardingStatistics.countDocsDeletedByRangeDeleter
MongoDB 在数据段迁移期间在源分片的主节点上删除文档的累积数量,该计数会持续增加。
仅当在分片上运行时才出现。
shardingStatistics.countDonorMoveChunkLockTimeout
MongoDB 因锁获取超时而在源分片的主节点上中止数据段迁移的累计次数,该计数会持续增加。
仅当在分片上运行时才出现。
shardingStatistics.unfinishedMigrationFromPreviousPrimary
选举后上一个主节点留下的未完成迁移数。只有在新当选的
mongod
转换为主节点的过程完成后,该值才会更新。仅当在分片上运行时才出现。
shardingStatistics.chunkMigrationConcurrency
源分片和接收分片上用于执行数据段迁移操作的线程数。
仅当在分片上运行时才出现。
从 MongoDB 5.0.15开始提供。
shardingStatistics.rangeDeleterTasks
已准备好运行或正在作为数据段迁移进程的一部分运行的排队数据段范围删除任务的当前总数。
查看
config.rangeDeletions
集合中的文档,了解数据段迁移后有待从分片中删除的数据段范围的信息。仅在分片节点上运行时出现。
shardingStatistics.resharding
包含重新分片操作相关统计信息的文档。
每个分片都返回自己的重新分片操作统计数据。如果分片不参与重新分片操作,则该分片将不包含有关重新分片操作的统计数据。
仅当对分片或配置服务器上运行时才存在。
版本 5.0 中的新增功能。
shardingStatistics.resharding.countReshardingOperations
countReshardingSuccessful
、countReshardingFailures
和countReshardingCanceled
的总和。如果重新分片操作已开始但尚未完成,则总和值将进一步加1
。当mongod
启动或重新启动时,总和值将被设置为 0。仅当对分片或配置服务器上运行时才存在。
版本 5.0 中的新增功能。
shardingStatistics.resharding.countReshardingSuccessful
成功执行重新分片操作的次数。启动或重新启动
mongod
时,该数字将被设置为 0。仅当对分片或配置服务器上运行时才存在。
版本 5.0 中的新增功能。
shardingStatistics.resharding.countReshardingFailures
重新分片操作失败的次数。启动或重新启动
mongod
时,该数字将被设置为 0。仅当对分片或配置服务器上运行时才存在。
版本 5.0 中的新增功能。
shardingStatistics.resharding.countReshardingCanceled
取消的重新分片操作的数量。启动或重新启动
mongod
时,该数字将被设置为 0。仅当对分片或配置服务器上运行时才存在。
版本 5.0 中的新增功能。
shardingStatistics.resharding.totalOperationTimeElapsedMillis
当前重新分片操作所用的总时间(毫秒)。开始新的重新分片操作时,时间将被设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.remainingOperationTimeEstimatedMillis
当前重新分片操作的估计剩余时间(以毫秒为单位)。 当新的重新分片操作开始时,时间设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.approxDocumentsToCopy
当前重新分片操作要从发送分片复制到接收分片的大致文档数量。 数字是重新分片操作开始时设置的估计值,并且该数字不会随着操作的进行而更新。 当新的重新分片操作开始时,数字设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.documentsCopied
当前重新分片操作中从发送分片复制到接收分片的文档数量。开始新的重新分片操作时,该数字将被设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.approxBytesToCopy
当前重新分片操作从发送分片复制到接收分片的大致字节数。 数字是重新分片操作开始时设置的估计值,并且该数字不会随着操作的进行而更新。 当新的重新分片操作开始时,数字设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.bytesCopied
当前重新分片操作中从发送分片复制到接收分片的字节数量。开始新的重新分片操作时,该数字将被设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.totalCopyTimeElapsedMillis
当前重新分片操作从发送分片到接收分片的持续数据复制任务所花费的总时间(毫秒)。 当新的重新分片操作开始时,时间设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.oplogEntriesFetched
从当前重新分片操作的 oplog 获取的条目数。开始新的重新分片操作时,该数字将被设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
shardingStatistics.resharding.oplogEntriesApplied
应用于当前重新分片操作的 oplog 的条目数。开始新的重新分片操作时,该数字将被设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.totalApplyTimeElapsedMillis
当前重新分片操作的应用步骤所用的总时间(毫秒)。在应用步骤中,接收分片根据来自发送分片的新传入写入来修改其数据。开始新的重新分片操作时,时间将被设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.countWritesDuringCriticalSection
当前重新分片操作在关键部分执行的写入次数。关键部分可防止对当前正在重新分片的集合进行新的传入写入。开始新的重新分片操作时,该数字将被设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.totalCriticalSectionTimeElapsedMillis
当前重新分片操作的关键部分所用的总时间(毫秒)。关键部分可防止对当前正在重新分片的集合进行新的传入写入。开始新的重新分片操作时,时间将被设置为 0。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.donorState
当前重新分片操作的发送分片的状态。开始新的重新分片操作时,该数字将被设置为 0。
返回的数字含义说明0
unused
该分片不是当前重新分片操作中的发送分片。
1
preparing-to-donate
源分片正准备向接收分片提供数据。
2
donating-initial-data
发送分片正在向接收分片发送数据。
3
donating-oplog-entries
发送分片正在向接收分片发送 oplog 条目。
4
preparing-to-block-writes
发送分片即将阻止对正在重新分片的集合进行新的传入写入操作。
5
error
重新分片操作过程中发生错误。
6
blocking-writes
发送分片正在阻止新的传入写入操作,并且发送分片已通知所有接收分片新的传入写入已禁止。
7
done
发送分片已经删除旧的分片集合,重新分片操作已完成。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.resharding.recipientState
当前重新分片操作的接收分片的状态。开始新的重新分片操作时,该数字将被设置为 0。
返回的数字含义说明0
unused
分片不是当前重新分片操作中的接收分片。
1
awaiting-fetch-timestamp
接收分片正在等待发送分片做好发送数据的准备
2
creating-collection
接收分片正在创建新的分片集合。
3
cloning
接收分片正在接收来自发送分片的数据。
4
applying
接收分片正在应用 oplog 条目,以根据来自发送分片的新传入写入来修改数据副本。
5
error
重新分片操作过程中发生错误。
6
strict-consistency
接收分片将所有数据更改存储在临时集合中。
7
done
重新分片操作已完成。
仅当对分片或配置服务器上运行时才存在。对配置服务器运行时则返回 0。
版本 5.0 中的新增功能。
shardingStatistics.numHostsTargeted
指示针对
CRUD
操作和聚合命令的分片数量。运行CRUD
操作或聚合命令时,以下指标将递增。名称说明allShards
针对所有分片的命令
manyShards
针对多个分片的命令
oneShard
针对一个分片的命令
unsharded
在未分片的集合上运行的命令
注意
在
mongos
上运行serverStatus
命令可以深入了解在分片集群上运行的 CRUD 和聚合操作。多分片操作可以是分散收集,也可以特定于分片。多分片分散收集操作可能会消耗更多资源。使用
shardingStatistics.numHostsTargeted
指标,可以调整在分片集群上运行的聚合查询。
shardingStatistics.resharding.coordinatorState
当前重新分片操作的重新分片协调器的状态。重新分片协调器是在配置服务器主节点上运行的线程。开始新的重新分片操作时,该数字将被设置为 0。
返回的数字含义说明0
unused
该分片不是当前重新分片操作中的协调者。
1
initializing
重新分片协调器已将协调器文档插入
config.reshardingOperations
中,并将reshardingFields
添加到原始集合的config.collections
条目中。2
preparing-to-donate
重新分片协调器
已为临时重新分片集合创建了一个
config.collections
条目。已在
config.chunks
中插入了基于新分片键的范围条目。已将条目插入到与新分片键关联的任何区域的
config.tags
中。
协调器通知参与分片开始重新分片操作。然后,协调器将等待,直到所有发送分片都选择了一个
minFetchTimestamp
并准备好发送。3
cloning
重新分片协调节点通知发送分片将数据发送给接收分片。协调节点等待所有接收分片完成对发送分片数据的克隆。
4
applying
重新分片协调器通知接收分片根据来自发送分片的新传入写入来修改其数据副本。协调器等待所有接收分片完成应用 oplog 条目。
5
blocking-writes
重新分片协调节点通知发送分片,以防止对正在重新分片的集合进行新的传入写入操作。然后,协调节点等待所有接收分片进行所有数据更改。
6
aborting
在重新分片操作或运行
abortReshardCollection
命令(或sh.abortReshardCollection()
方法)期间出现不可恢复的错误。6
committing
重新分片协调器删除了临时重新分区集合的
config.collections
条目。然后,协调器将recipientFields
添加到源集合的条目中。仅当对分片或配置服务器上运行时才存在。
版本 5.0 中的新增功能。
shardingStatistics.resharding.opStatus
当前重新分片操作的状态。
返回的数字说明-1
重新分片操作不在进行中。
0
重新分片操作成功。
1
重新分片操作失败。
2
重新分片操作已取消。
仅当对分片或配置服务器上运行时才存在。
版本 5.0 中的新增功能。
shardedIndexConsistency
shardedIndexConsistency : { numShardedCollectionsWithInconsistentIndexes : Long("<num>") },
shardedIndexConsistency
仅在配置服务器实例上可用。
一份文档:返回分片集合索引一致性检查的结果。
仅当在分片集群的配置服务器副本集的主节点上运行时,返回的指标才有意义。
提示
另请参阅:
enableShardedIndexConsistencyCheck
parametershardedIndexConsistencyCheckIntervalMS
parameter
shardedIndexConsistency.numShardedCollectionsWithInconsistentIndexes
仅在配置服务器实例上可用。
分片之间索引不一致的分片集合的数量。如果分片集合在包含集合数据段的每个分片上不具有完全相同的索引(包括索引选项),则分片集合的索引不一致。
要确认分片集合是否存在不一致的索引,请参阅查找分片间不一致的索引。
仅当在分片集群的配置服务器副本集的主节点上运行时,返回的指标才有意义。
提示
另请参阅:
enableShardedIndexConsistencyCheck
parametershardedIndexConsistencyCheckIntervalMS
parameter
引擎加密
storageEngine : { name : <string>, supportsCommittedReads : <boolean>, persistent : <boolean> },
storageEngine.supportsCommittedReads
版本 3.2 中的新增功能。
一个布尔值,指示存储引擎是否支持
"majority"
读关注。
storageEngine.persistent
3.2.6版本新增。
一个布尔值,指示存储引擎是否将数据持久存储到磁盘。
事务
3.6.3版本新增。
transactions : { retriedCommandsCount : Long("<num>"), retriedStatementsCount : Long("<num>"), transactionsCollectionWriteCount : Long("<num>"), currentActive : Long("<num>"), currentInactive : Long("<num>"), currentOpen : Long("<num>"), totalAborted : Long("<num>"), totalCommitted : Long("<num>"), totalStarted : Long("<num>"), totalPrepared : Long("<num>"), totalPreparedThenCommitted : Long("<num>"), totalPreparedThenAborted : Long("<num>"), currentPrepared : Long("<num>"), lastCommittedTransaction : <document> },
transactions : { currentOpen : Long("<num>"), currentActive : Long("<num>"), currentInactive : Long("<num>"), totalStarted : Long("<num>"), totalCommitted : Long("<num>"), totalAborted : Long("<num>"), abortCause : { <String1> : Long("<num>"), <String2> : Long("<num>"), ... }, totalContactedParticipants : Long("<num>"), totalParticipantsAtCommit : Long("<num>"), totalRequestsTargeted : Long("<num>"), commitTypes : { noShards : { initiated : Long("<num>"), successful : Long("<num>"), successfulDurationMicros : Long("<num>") }, singleShard : { initiated : Long("<num>"), successful : Long("<num>"), successfulDurationMicros : Long("<num>") }, singleWriteShard : { initiated : Long("<num>"), successful : Long("<num>"), successfulDurationMicros : Long("<num>") }, readOnly : { initiated : Long("<num>"), successful : Long("<num>"), successfulDurationMicros : Long("<num>") }, twoPhaseCommit : { initiated : Long("<num>"), successful : Long("<num>"), successfulDurationMicros : Long("<num>") }, recoverWithToken : { initiated : Long("<num>"), successful : Long("<num>"), successfulDurationMicros : Long("<num>") } } },
transactions.retriedCommandsCount
仅在 mongod 上可用。
提交相应可重试写入命令后收到的重试总次数。也就是说,即使先前的写入已经成功,并在
config.transactions
集合中拥有事务和会话的关联记录,仍会尝试可重试写入,例如,对客户端的初始写入响应丢失时。注意
MongoDB 不会重新执行已提交的写入。
总数是所有会话中的总和值。
总数不包括在数据段迁移过程中可能在内部发生的任何可重试写入。
3.6.3版本新增。
transactions.retriedStatementsCount
仅在 mongod 上可用。
与
transactions.retriedCommandsCount
中的重试命令关联的写入语句总数。注意
MongoDB 不会重新执行已提交的写入。
总数不包括在数据段迁移过程中可能在内部发生的任何可重试写入。
3.6.3版本新增。
transactions.transactionsCollectionWriteCount
仅在 mongod 上可用。
在提交新的可重试写入语句时触发的写入
config.transactions
集合的总次数。对于更新和删除命令,由于只能重试单个文档操作,因此每个语句都只有一次写入。
对于插入操作,每批插入的文档只有一次写入,除非失败导致单独插入每个文档。
该总数包括在迁移过程中写入服务器的
config.transactions
集合的次数。3.6.3版本新增。
transactions.abortCause
仅适用于 mongos。
按原因对
transactions.totalAborted
进行细分。如果客户端发出显式abortTransaction
,则原因列为abort
。例如:
totalAborted : Long("5"), abortCause : { abort : Long("1"), DuplicateKey : Long("1"), StaleConfig : Long("3"), SnapshotTooOld : Long("1") },
transactions.totalContactedParticipants
仅适用于 mongos。
自上次启动以来,针对通过此
mongos
启动的所有事务接触的分片总数。在事务处理期间联系的分片的数量可以包括提交中可能不包含的分片。
transactions.totalParticipantsAtCommit
仅适用于 mongos。
自上次启动以来,通过此
mongos
启动的所有事务的提交所涉及的分片总数。
transactions.totalRequestsTargeted
仅适用于 mongos。
mongos
作为其事务的一部分所针对的网络请求总数。
transactions.commitTypes
仅适用于 mongos。
按类型细分提交。例如:
noShards : { initiated : Long("0"), successful : Long("0"), successfulDurationMicros : Long("0") }, singleShard : { initiated : Long("5"), successful : Long("5"), successfulDurationMicros : Long("203118") }, singleWriteShard : { initiated : Long("0"), successful : Long("0"), successfulDurationMicros : Long("0") }, readOnly : { initiated : Long("0"), successful : Long("0"), successfulDurationMicros : Long("0") }, twoPhaseCommit : { initiated : Long("1"), successful : Long("1"), successfulDurationMicros : Long("179616") }, recoverWithToken : { initiated : Long("0"), successful : Long("0"), successfulDurationMicros : Long("0") } 提交类型为:
类型说明noShards
提交未接触任何分片的事务。
singleShard
提交影响单个分片的事务。
singleWriteShard
联系到多个分片,但其写入操作仅影响单个分片的事务提交。
readOnly
提交仅涉及读取操作的事务。
twoPhaseCommit
提交包含写入多个分片的事务。
recoverWithToken
提交从另一个实例或该实例重新启动后恢复事务结果。
对于每种提交类型,命令都会返回以下指标:
衡量标准说明initiated
启动此类型提交的总次数。
successful
此类提交成功的总次数。
successfulDurationMicros
成功提交此类型所花费的总时间(以微秒为单位)。
transactions.totalPrepared
仅在 mongod 上可用。
自
mongod
进程上次启动以来,此服务器上处于准备状态的事务总数。
transactions.totalPreparedThenCommitted
仅在 mongod 上可用。
自
mongod
进程上次启动以来,在此服务器上准备和提交的事务总数。
transactions.totalPreparedThenAborted
仅在 mongod 上可用。
自
mongod
进程上次启动以来,在此服务器上准备和中止的事务总数。
transactions.lastCommittedTransaction
仅在 mongod 上可用。
mongod
为主节点时提交的最后一个事务的详细信息。通过从节点返回时,
lastCommittedTransaction
返回该从节点作为主节点时提交的最后一个事务的详细信息。lastCommittedTransaction : { operationCount : Long("1"), oplogOperationBytes : Long("211"), writeConcern : { w : "majority", wtimeout : 0 } } 衡量标准说明operationCount
事务中写入操作的数量。
oplogOperationBytes
事务对应的一个或多个 oplog 条目的大小。[2]
writeConcern
用于事务的写关注。
[2] | MongoDB 根据需要创建尽可能多的 oplog 条目,以封装事务中的所有写入操作。有关详细信息,请参阅 Oplog 大小限制。 |
transportSecurity
transportSecurity : { 1.0 : Long("<num>"), 1.1 : Long("<num>"), 1.2 : Long("<num>"), 1.3 : Long("<num>"), unknown : Long("<num>") },
watchdog
版本 3.6 中的新增功能。
watchdog : { checkGeneration : Long("<num>"), monitorGeneration : Long("<num>"), monitorPeriod : <num> }
注意
watchdog
部分仅在启用存储节点看门狗时出现。
watchdog
一个文档,其中报告存储节点看门狗的状态。
watchdog.monitorGeneration
检查
mongod
使用的所有文件系统的状态的次数。该值在每个monitoringPeriod
中递增一次。
watchdog.monitorPeriod
由
watchdogPeriodSeconds
设置的值。这是状态检查之间的时间段。
WiredTiger
wiredTiger
信息仅在使用 WiredTiger 存储引擎时才显示。服务器的一些统计数据会汇总。
{ uri : 'statistics:', async : { current work queue length : <num>, maximum work queue length : <num>, number of allocation state races : <num>, number of flush calls : <num>, number of operation slots viewed for allocation : <num>, number of times operation allocation failed : <num>, number of times worker found no work : <num>, total allocations : <num>, total compact calls : <num>, total insert calls : <num>, total remove calls : <num>, total search calls : <num>, total update calls : <num> }, block-manager : { blocks pre-loaded : <num>, blocks read : <num>, blocks written : <num>, bytes read : <num>, bytes written : <num>, bytes written for checkpoint : <num>, mapped blocks read : <num>, mapped bytes read : <num> }, cache : { application threads page read from disk to cache count : <num>, application threads page read from disk to cache time (usecs) : <num>, application threads page write from cache to disk count : <num>, application threads page write from cache to disk time (usecs) : <num>, bytes belonging to page images in the cache : <num>, bytes belonging to the cache overflow table in the cache : <num>, bytes currently in the cache : <num>, bytes dirty in the cache cumulative : <num>, bytes not belonging to page images in the cache : <num>, bytes read into cache : <num>, bytes written from cache : <num>, cache overflow cursor application thread wait time (usecs) : <num>, cache overflow cursor internal thread wait time (usecs) : <num>, cache overflow score : <num>, cache overflow table entries : <num>, cache overflow table insert calls : <num>, cache overflow table max on-disk size : <num>, cache overflow table on-disk size : <num>, cache overflow table remove calls : <num>, checkpoint blocked page eviction : <num>, eviction calls to get a page : <num>, eviction calls to get a page found queue empty : <num>, eviction calls to get a page found queue empty after locking : <num>, eviction currently operating in aggressive mode : <num>, eviction empty score : <num>, eviction passes of a file : <num>, eviction server candidate queue empty when topping up : <num>, eviction server candidate queue not empty when topping up : <num>, eviction server evicting pages : <num>, eviction server slept, because we did not make progress with eviction : <num>, eviction server unable to reach eviction goal : <num>, eviction server waiting for a leaf page : <num>, eviction server waiting for an internal page sleep (usec) : <num>, eviction server waiting for an internal page yields : <num>, eviction state : <num>, eviction walk target pages histogram - 0-9 : <num>, eviction walk target pages histogram - 10-31 : <num>, eviction walk target pages histogram - 128 and higher : <num>, eviction walk target pages histogram - 32-63 : <num>, eviction walk target pages histogram - 64-128 : <num>, eviction walks abandoned : <num>, eviction walks gave up because they restarted their walk twice : <num>, eviction walks gave up because they saw too many pages and found no candidates : <num>, eviction walks gave up because they saw too many pages and found too few candidates : <num>, eviction walks reached end of tree : <num>, eviction walks started from root of tree : <num>, eviction walks started from saved location in tree : <num>, eviction worker thread active : <num>, eviction worker thread created : <num>, eviction worker thread evicting pages : <num>, eviction worker thread removed : <num>, eviction worker thread stable number : <num>, files with active eviction walks : <num>, files with new eviction walks started : <num>, force re-tuning of eviction workers once in a while : <num>, forced eviction - pages evicted that were clean count : <num>, forced eviction - pages evicted that were clean time (usecs) : <num>, forced eviction - pages evicted that were dirty count : <num>, forced eviction - pages evicted that were dirty time (usecs) : <num>, forced eviction - pages selected because of too many deleted items count : <num>, forced eviction - pages selected count : <num>, forced eviction - pages selected unable to be evicted count : <num>, forced eviction - pages selected unable to be evicted time : <num>, hazard pointer blocked page eviction : <num>, hazard pointer check calls : <num>, hazard pointer check entries walked : <num>, hazard pointer maximum array length : <num>, in-memory page passed criteria to be split : <num>, in-memory page splits : <num>, internal pages evicted : <num>, internal pages split during eviction : <num>, leaf pages split during eviction : <num>, maximum bytes configured : <num>, maximum page size at eviction : <num>, modified pages evicted : <num>, modified pages evicted by application threads : <num>, operations timed out waiting for space in cache : <num>, overflow pages read into cache : <num>, page split during eviction deepened the tree : <num>, page written requiring cache overflow records : <num>, pages currently held in the cache : <num>, pages evicted by application threads : <num>, pages queued for eviction : <num>, pages queued for eviction post lru sorting : <num>, pages queued for urgent eviction : <num>, pages queued for urgent eviction during walk : <num>, pages read into cache : <num>, pages read into cache after truncate : <num>, pages read into cache after truncate in prepare state : <num>, pages read into cache requiring cache overflow entries : <num>, pages read into cache requiring cache overflow for checkpoint : <num>, pages read into cache skipping older cache overflow entries : <num>, pages read into cache with skipped cache overflow entries needed later : <num>, pages read into cache with skipped cache overflow entries needed later by checkpoint : <num>, pages requested from the cache : <num>, pages seen by eviction walk : <num>, pages selected for eviction unable to be evicted : <num>, pages walked for eviction : <num>, pages written from cache : <num>, pages written requiring in-memory restoration : <num>, percentage overhead : <num>, tracked bytes belonging to internal pages in the cache : <num>, tracked bytes belonging to leaf pages in the cache : <num>, tracked dirty bytes in the cache : <num>, tracked dirty pages in the cache : <num>, unmodified pages evicted : <num> }, capacity : { background fsync file handles considered : <num>, background fsync file handles synced : <num>, background fsync time (msecs) : <num>, bytes read : <num>, bytes written for checkpoint : <num>, bytes written for eviction : <num>, bytes written for log : <num>, bytes written total : <num>, threshold to call fsync : <num>, time waiting due to total capacity (usecs) : <num>, time waiting during checkpoint (usecs) : <num>, time waiting during eviction (usecs) : <num>, time waiting during logging (usecs) : <num>, time waiting during read (usecs) : <num> }, connection : { auto adjusting condition resets : <num>, auto adjusting condition wait calls : <num>, detected system time went backwards : <num>, files currently open : <num>, memory allocations : <num>, memory frees : <num>, memory re-allocations : <num>, pthread mutex condition wait calls : <num>, pthread mutex shared lock read-lock calls : <num>, pthread mutex shared lock write-lock calls : <num>, total fsync I/Os : <num>, total read I/Os : <num>, total write I/Os : <num> }, cursor : { cached cursor count : <num>, cursor bulk loaded cursor insert calls : <num>, cursor close calls that result in cache : <num>, cursor create calls : <num>, cursor insert calls : <num>, cursor insert key and value bytes : <num>, cursor modify calls : <num>, cursor modify key and value bytes affected : <num>, cursor modify value bytes modified : <num>, cursor next calls : <num>, cursor operation restarted : <num>, cursor prev calls : <num>, cursor remove calls : <num>, cursor remove key bytes removed : <num>, cursor reserve calls : <num>, cursor reset calls : <num>, cursor search calls : <num>, cursor search near calls : <num>, cursor sweep buckets : <num>, cursor sweep cursors closed : <num>, cursor sweep cursors examined : <num>, cursor sweeps : <num>, cursor truncate calls : <num>, cursor update calls : <num>, cursor update key and value bytes : <num>, cursor update value size change : <num>, cursors reused from cache : <num>, open cursor count : <num> }, data-handle : { connection data handle size : <num>, connection data handles currently active : <num>, connection sweep candidate became referenced : <num>, connection sweep dhandles closed : <num>, connection sweep dhandles removed from hash list : <num>, connection sweep time-of-death sets : <num>, connection sweeps : <num>, session dhandles swept : <num>, session sweep attempts : <num> }, lock : { checkpoint lock acquisitions : <num>, checkpoint lock application thread wait time (usecs) : <num>, checkpoint lock internal thread wait time (usecs) : <num>, dhandle lock application thread time waiting (usecs) : <num>, dhandle lock internal thread time waiting (usecs) : <num>, dhandle read lock acquisitions : <num>, dhandle write lock acquisitions : <num>, durable timestamp queue lock application thread time waiting (usecs) : <num>, durable timestamp queue lock internal thread time waiting (usecs) : <num>, durable timestamp queue read lock acquisitions : <num>, durable timestamp queue write lock acquisitions : <num>, metadata lock acquisitions : <num>, metadata lock application thread wait time (usecs) : <num>, metadata lock internal thread wait time (usecs) : <num>, read timestamp queue lock application thread time waiting (usecs) : <num>, read timestamp queue lock internal thread time waiting (usecs) : <num>, read timestamp queue read lock acquisitions : <num>, read timestamp queue write lock acquisitions : <num>, schema lock acquisitions : <num>, schema lock application thread wait time (usecs) : <num>, schema lock internal thread wait time (usecs) : <num>, table lock application thread time waiting for the table lock (usecs) : <num>, table lock internal thread time waiting for the table lock (usecs) : <num>, table read lock acquisitions : <num>, table write lock acquisitions : <num>, txn global lock application thread time waiting (usecs) : <num>, txn global lock internal thread time waiting (usecs) : <num>, txn global read lock acquisitions : <num>, txn global write lock acquisitions : <num> }, log : { busy returns attempting to switch slots : <num>, force archive time sleeping (usecs) : <num>, log bytes of payload data : <num>, log bytes written : <num>, log files manually zero-filled : <num>, log flush operations : <num>, log force write operations : <num>, log force write operations skipped : <num>, log records compressed : <num>, log records not compressed : <num>, log records too small to compress : <num>, log release advances write LSN : <num>, log scan operations : <num>, log scan records requiring two reads : <num>, log server thread advances write LSN : <num>, log server thread write LSN walk skipped : <num>, log sync operations : <num>, log sync time duration (usecs) : <num>, log sync_dir operations : <num>, log sync_dir time duration (usecs) : <num>, log write operations : <num>, logging bytes consolidated : <num>, maximum log file size : <num>, number of pre-allocated log files to create : <num>, pre-allocated log files not ready and missed : <num>, pre-allocated log files prepared : <num>, pre-allocated log files used : <num>, records processed by log scan : <num>, slot close lost race : <num>, slot close unbuffered waits : <num>, slot closures : <num>, slot join atomic update races : <num>, slot join calls atomic updates raced : <num>, slot join calls did not yield : <num>, slot join calls found active slot closed : <num>, slot join calls slept : <num>, slot join calls yielded : <num>, slot join found active slot closed : <num>, slot joins yield time (usecs) : <num>, slot transitions unable to find free slot : <num>, slot unbuffered writes : <num>, total in-memory size of compressed records : <num>, total log buffer size : <num>, total size of compressed records : <num>, written slots coalesced : <num>, yields waiting for previous log file close : <num> }, perf : { file system read latency histogram (bucket 1) - 10-49ms : <num>, file system read latency histogram (bucket 2) - 50-99ms : <num>, file system read latency histogram (bucket 3) - 100-249ms : <num>, file system read latency histogram (bucket 4) - 250-499ms : <num>, file system read latency histogram (bucket 5) - 500-999ms : <num>, file system read latency histogram (bucket 6) - 1000ms+ : <num>, file system write latency histogram (bucket 1) - 10-49ms : <num>, file system write latency histogram (bucket 2) - 50-99ms : <num>, file system write latency histogram (bucket 3) - 100-249ms : <num>, file system write latency histogram (bucket 4) - 250-499ms : <num>, file system write latency histogram (bucket 5) - 500-999ms : <num>, file system write latency histogram (bucket 6) - 1000ms+ : <num>, operation read latency histogram (bucket 1) - 100-249us : <num>, operation read latency histogram (bucket 2) - 250-499us : <num>, operation read latency histogram (bucket 3) - 500-999us : <num>, operation read latency histogram (bucket 4) - 1000-9999us : <num>, operation read latency histogram (bucket 5) - 10000us+ : <num>, operation write latency histogram (bucket 1) - 100-249us : <num>, operation write latency histogram (bucket 2) - 250-499us : <num>, operation write latency histogram (bucket 3) - 500-999us : <num>, operation write latency histogram (bucket 4) - 1000-9999us : <num>, operation write latency histogram (bucket 5) - 10000us+ : <num> }, reconciliation : { fast-path pages deleted : <num>, page reconciliation calls : <num>, page reconciliation calls for eviction : <num>, pages deleted : <num>, split bytes currently awaiting free : <num>, split objects currently awaiting free : <num> }, session : { open session count : <num>, session query timestamp calls : <num>, table alter failed calls : <num>, table alter successful calls : <num>, table alter unchanged and skipped : <num>, table compact failed calls : <num>, table compact successful calls : <num>, table create failed calls : <num>, table create successful calls : <num>, table drop failed calls : <num>, table drop successful calls : <num>, table import failed calls : <num>, table import successful calls : <num>, table rebalance failed calls : <num>, table rebalance successful calls : <num>, table rename failed calls : <num>, table rename successful calls : <num>, table salvage failed calls : <num>, table salvage successful calls : <num>, table truncate failed calls : <num>, table truncate successful calls : <num>, table verify failed calls : <num>, table verify successful calls : <num> }, thread-state : { active filesystem fsync calls : <num>, active filesystem read calls : <num>, active filesystem write calls : <num> }, thread-yield : { application thread time evicting (usecs) : <num>, application thread time waiting for cache (usecs) : <num>, connection close blocked waiting for transaction state stabilization : <num>, connection close yielded for lsm manager shutdown : <num>, data handle lock yielded : <num>, get reference for page index and slot time sleeping (usecs) : <num>, log server sync yielded for log write : <num>, page access yielded due to prepare state change : <num>, page acquire busy blocked : <num>, page acquire eviction blocked : <num>, page acquire locked blocked : <num>, page acquire read blocked : <num>, page acquire time sleeping (usecs) : <num>, page delete rollback time sleeping for state change (usecs) : <num>, page reconciliation yielded due to child modification : <num> }, transaction : { Number of prepared updates : <num>, Number of prepared updates added to cache overflow : <num>, Number of prepared updates resolved : <num>, durable timestamp queue entries walked : <num>, durable timestamp queue insert to empty : <num>, durable timestamp queue inserts to head : <num>, durable timestamp queue inserts total : <num>, durable timestamp queue length : <num>, number of named snapshots created : <num>, number of named snapshots dropped : <num>, prepared transactions : <num>, prepared transactions committed : <num>, prepared transactions currently active : <num>, prepared transactions rolled back : <num>, query timestamp calls : <num>, read timestamp queue entries walked : <num>, read timestamp queue insert to empty : <num>, read timestamp queue inserts to head : <num>, read timestamp queue inserts total : <num>, read timestamp queue length : <num>, rollback to stable calls : <num>, rollback to stable updates aborted : <num>, rollback to stable updates removed from cache overflow : <num>, set timestamp calls : <num>, set timestamp durable calls : <num>, set timestamp durable updates : <num>, set timestamp oldest calls : <num>, set timestamp oldest updates : <num>, set timestamp stable calls : <num>, set timestamp stable updates : <num>, transaction begins : <num>, transaction checkpoint currently running : <num>, transaction checkpoint generation : <num>, transaction checkpoint max time (msecs) : <num>, transaction checkpoint min time (msecs) : <num>, transaction checkpoint most recent time (msecs) : <num>, transaction checkpoint scrub dirty target : <num>, transaction checkpoint scrub time (msecs) : <num>, transaction checkpoint total time (msecs) : <num>, transaction checkpoints : <num>, transaction checkpoints skipped because database was clean : <num>, transaction failures due to cache overflow : <num>, transaction fsync calls for checkpoint after allocating the transaction ID : <num>, transaction fsync duration for checkpoint after allocating the transaction ID (usecs) : <num>, transaction range of IDs currently pinned : <num>, transaction range of IDs currently pinned by a checkpoint : <num>, transaction range of IDs currently pinned by named snapshots : <num>, transaction range of timestamps currently pinned : <num>, transaction range of timestamps pinned by a checkpoint : <num>, transaction range of timestamps pinned by the oldest active read timestamp : <num>, transaction range of timestamps pinned by the oldest timestamp : <num>, transaction read timestamp of the oldest active reader : <num>, transaction sync calls : <num>, transactions committed : <num>, transactions rolled back : <num>, update conflicts : <num> }, concurrentTransactions : { write : { out : <num>, available : <num>, totalTickets : <num> }, read : { out : <num>, available : <num>, totalTickets : <num> } }, snapshot-window-settings : { total number of SnapshotTooOld errors : <num>, max target available snapshots window size in seconds : <num>, target available snapshots window size in seconds : <num>, current available snapshots window size in seconds : <num>, latest majority snapshot timestamp available : <string>, oldest majority snapshot timestamp available : <string> } }
注意
以下并非详尽列表。
wiredTiger.cache
返回有关缓存和从缓存中逐出页面的统计数据的文档。
下面介绍一些关键
wiredTiger.cache
统计数据:wiredTiger.cache.tracked dirty bytes in the cache
缓存中脏数据的大小(字节)。该值应小于
bytes currently in the cache
值。
wiredTiger.cache.pages read into cache
读入缓存的页数。
wiredTiger.cache.pages read into cache
和wiredTiger.cache.pages written from cache
可以概述 I/O 活动。
wiredTiger.cache.pages written from cache
从缓存写入的页数。
wiredTiger.cache.pages written from cache
和wiredTiger.cache.pages read into cache
可以概述 I/O 活动。
如需调整 WiredTiger 内部缓存大小,请参阅
storage.wiredTiger.engineConfig.cacheSizeGB
和--wiredTigerCacheSizeGB
。避免将 WiredTiger 内部缓存大小增加到超过其默认值。
wiredTiger.concurrentTransactions
一个文档,返回有关允许进入 WiredTiger storage engine 的写事务(write transaction)并发数信息。这些设置特定于 MongoDB。
要更改并发读取和写入事务的设置,请参阅
wiredTigerConcurrentReadTransactions
和wiredTigerConcurrentWriteTransactions
。
writeBacksQueued
writeBacksQueued : <boolean>,
writeBacksQueued
一个布尔值,指示是否有来自
mongos
实例的操作排队等待重试。通常,此值为 false。另请参阅 writeBacks。