$currentOp (aggregation)
Definition
$currentOpReturns a stream of documents containing information on active and/or dormant operations as well as inactive sessions that are holding locks as part of a transaction. The stage returns a document for each operation or session. To run
$currentOp, use thedb.aggregate()helper on theadmindatabase.The
$currentOpaggregation stage is preferred over thecurrentOpcommand and itsmongoshhelper methoddb.currentOp(). Because thecurrentOpcommand anddb.currentOp()helper method return the results in a single document, the total size of thecurrentOpresult set is subject to the maximum 16MB BSON size limit for documents. The$currentOpstage returns a cursor over a stream of documents, each of which reports a single operation. Each operation document is subject to the 16MB BSON limit, but unlike thecurrentOpcommand, there is no limit on the overall size of the result set.$currentOpalso enables you to perform arbitrary transformations of the results as the documents pass through the pipeline.
Syntax
{ $currentOp: { allUsers: <boolean>, idleConnections: <boolean>, idleCursors: <boolean>, idleSessions: <boolean>, localOps: <boolean> } }
$currentOp takes an options document as its operand:
Option | Description |
|---|---|
Boolean.
For standalone and replica sets that enforce access control, For sharded clusters that enforce access control, the Defaults to | |
Boolean. If set to Defaults to | |
Boolean. If set to Information on idle cursors have the Information on cursors currently active in a
Defaults to | |
Boolean.
Defaults to | |
Boolean. If set to The Defaults to | |
Boolean. Determines whether callstack information is returned as
part of the
Defaults to |
Omitting any of the above parameters causes $currentOp to use that parameter's default value. Specify an empty document, as shown below, to use the default values of all parameters.
{ $currentOp: { } }
Constraints
Pipeline
$currentOpmust be the first stage in the pipeline.Pipelines that start with
$currentOpcan only be run on theadmindatabase.
Access Control
For standalone and replica sets that enforce access control,
inprogprivilege is required to run$currentOpif allUsers: true.For sharded clusters that enforce access control, the
inprogprivilege is required to run$currentOp.
Transactions
$currentOpis not allowed in transactions.
Redaction
When using Queryable Encryption,
$currentOp output redacts certain information:
The output omits all fields after
"command".The output redacts
"command"to include only the first element,$comment, and$db.
Examples
The following examples show how to use the $currentOp aggregation
stage.
Inactive Sessions
This example returns information on inactive sessions that are holding locks as part of a transaction. Specifically:
The first stage returns documents for all active operations as well as inactive sessions that are holding locks as part of a transaction.
The second stage filters for documents related to inactive sessions that are holding locks as part of a transaction.
db.getSiblingDB("admin").aggregate( [ { $currentOp : { allUsers: true, idleSessions: true } }, { $match : { active: false, transaction : { $exists: true } } } ] )
You can use $currentOp.type to specify
an equivalent filter:
db.getSiblingDB("admin").aggregate( [ { $currentOp : { allUsers: true, idleSessions: true } }, { $match : { type: "idleSession" } } ] )
Tip
For transactions on a sharded cluster, include localOps:true in the previous examples for a composite view of the transactions.
Both operations return documents of the form:
When run on a mongod that is part of a replica set:
{ "type" : "idleSession", "host" : "example.mongodb.com:27017", "desc" : "inactive transaction", "client" : "198.51.100.1:50428", "connectionId" : NumberLong(32), "appName" : "", "clientMetadata" : { "driver" : { "name" : "PyMongo", "version" : "3.9.0" }, "os" : { "type" : "Darwin", "name" : "Darwin", "architecture" : "x86_64", "version" : "10.14.5" }, "platform" : "CPython 3.7.1.final.0" }, "lsid" : { "id" : UUID("ff21e1a9-a130-4fe0-942f-9e6b6c67ea3c"), "uid" : BinData(0,"3pxqkATNUYKV/soT7qqKE0zC0BFb0pBz1pk4xXcSHsI=") }, "transaction" : { "parameters" : { "txnNumber" : NumberLong(4), "autocommit" : false, "readConcern" : { "level" : "snapshot", "afterClusterTime" : Timestamp(1563892246, 1) } }, "readTimestamp" : Timestamp(0, 0), "startWallClockTime" : "2019-07-23T10:30:49.461-04:00", "timeOpenMicros" : NumberLong(1913590), "timeActiveMicros" : NumberLong(55), "timeInactiveMicros" : NumberLong(1913535), "expiryTime" : "2019-07-23T10:31:49.461-04:00" }, "waitingForLock" : false, "active" : false, "locks" : { "ReplicationStateTransition" : "w", "Global" : "w", "Database" : "w", "Collection" : "w" }, "lockStats" : { "ReplicationStateTransition" : { "acquireCount" : { "w" : NumberLong(5) } }, "Global" : { "acquireCount" : { "r" : NumberLong(3), "w" : NumberLong(1) } }, "Database" : { "acquireCount" : { "r" : NumberLong(2), "w" : NumberLong(1) } }, "Collection" : { "acquireCount" : { "w" : NumberLong(1) } }, "Mutex" : { "acquireCount" : { "r" : NumberLong(3) } }, "oplog" : { "acquireCount" : { "r" : NumberLong(2) } } }, "waitingForFlowControl" : false, "flowControlStats" : {}, }
Running $currentOp with
localOps:true provides a
composite view (rather than per shard information) of the
in-progress transactions run on that mongos.
db.getSiblingDB("admin").aggregate( [ { $currentOp : { allUsers: true, idleSessions: true, localOps: true } }, { $match : { type: "idleSession" } } ] ); // or db.getSiblingDB("admin").aggregate( [ { $currentOp : { allUsers: true, idleSessions: true, localOps: true } }, { $match : { active: false, transaction : { $exists: true } } } ] )
{ "type" : "idleSession", "host" : "example.mongodb.com:27017", "desc" : "inactive transaction", "client" : "198.51.100.1:49618", "connectionId" : NumberLong(48), "appName" : "", "clientMetadata" : { "driver" : { "name" : "PyMongo", "version" : "3.9.0" }, "os" : { "type" : "Darwin", "name" : "Darwin", "architecture" : "x86_64", "version" : "10.14.6" }, "platform" : "CPython 3.7.1.final.0", "mongos" : { "host" : "example.mongodb.com:27017", "client" : "198.51.100.1:53268", "version" : "4.2.1" } }, "lsid" : { "id" : UUID("2c9ce111-133e-45b7-a00f-a7871005cae1"), "uid" : BinData(0,"3pxqkATNUYKV/soT7qqKE0zC0BFb0pBz1pk4xXcSHsI=") }, "active" : false, "transaction" : { "parameters" : { "txnNumber" : NumberLong(2), "autocommit" : false, "readConcern" : { "level" : "snapshot", "afterClusterTime" : Timestamp(1571869019, 2) } }, "globalReadTimestamp" : Timestamp(1571869019, 2), "startWallClockTime" : "2019-10-23T18:16:59.341-04:00", "timeOpenMicros" : NumberLong(169244639), "timeActiveMicros" : NumberLong(535), "timeInactiveMicros" : NumberLong(169244104), "numParticipants" : 2, "participants" : [ { "name" : "shardB", "coordinator" : true, "readOnly" : false }, { "name" : "shardA", "coordinator" : false, "readOnly" : false } ], "numReadOnlyParticipants" : 0, "numNonReadOnlyParticipants" : 2 } }
When run without localOps:true on
the mongos, the transaction information is per
shard.
When run on a mongos without localOps:true, the transaction information is per
shard.
{ "shard" : "shardB", "type" : "idleSession", "host" : "shardB.mongodb.com:27018", "desc" : "inactive transaction", "client_s" : "198.51.100.1:53961", "connectionId" : NumberLong(63), "appName" : "", "clientMetadata" : { "driver" : { "name" : "PyMongo", "version" : "3.9.0" }, "os" : { "type" : "Darwin", "name" : "Darwin", "architecture" : "x86_64", "version" : "10.14.6" }, "platform" : "CPython 3.7.1.final.0", "mongos" : { "host" : "example.mongodb.com:27017", "client" : "198.51.100.1:53976", "version" : "4.2.0" } }, "lsid" : { "id" : UUID("720d403c-8daf-40bb-b61e-329e20b0493b"), "uid" : BinData(0,"3pxqkATNUYKV/soT7qqKE0zC0BFb0pBz1pk4xXcSHsI=") }, "transaction" : { "parameters" : { "txnNumber" : NumberLong(1), "autocommit" : false, "readConcern" : { "level" : "snapshot" } }, "readTimestamp" : Timestamp(0, 0), "startWallClockTime" : "2019-10-21T18:31:12.192-04:00", "timeOpenMicros" : NumberLong(24137008), "timeActiveMicros" : NumberLong(52), "timeInactiveMicros" : NumberLong(24136956), "expiryTime" : "2019-10-21T18:32:12.192-04:00" }, "waitingForLock" : false, "active" : false, "locks" : { "ReplicationStateTransition" : "w", "Global" : "w", "Database" : "w", "Collection" : "w" }, "lockStats" : { "ReplicationStateTransition" : { "acquireCount" : { "w" : NumberLong(3) } }, "Global" : { "acquireCount" : { "r" : NumberLong(1), "w" : NumberLong(1) } }, "Database" : { "acquireCount" : { "r" : NumberLong(1), "w" : NumberLong(1) } }, "Collection" : { "acquireCount" : { "r" : NumberLong(1), "w" : NumberLong(1) } }, "Mutex" : { "acquireCount" : { "r" : NumberLong(6) } } } } { "shard" : "shardA", "type" : "idleSession", ... }
Sampled Queries
This example returns information on query sampling progess.
The first stage returns documents for all active operations.
The second stage filters for documents related to the query analyzer.
db.getSiblingDB("admin").aggregate( [ { $currentOp: { allUsers: true, localOps: true } }, { $match: { desc: "query analyzer" } } ] )
This pipeline returns output similar to the following:
When run on a mongod that is part of a replica set:
{ "desc" : "query analyzer", "ns" : "testDb.testColl", "collUuid" : UUID("ed9dfb1d-5b7c-4c6b-82e9-b0f537335795"), "samplesPerSecond" : 5, "startTime" : ISODate("2023-08-08T16:23:22.846Z"), "sampledReadsCount" : NumberLong(2), "sampledReadsBytes" : NumberLong(346), "sampledWritesCount" : NumberLong(3), "sampledWritesBytes" : NumberLong(904) }
When run on a mongos that is part of a sharded cluster:
{ "desc" : "query analyzer", "ns" : "testDb.testColl", "collUuid" : UUID("5130b4df-5966-434f-85f0-f8956b5ca74e"), "samplesPerSecond" : 5, "startTime" : ISODate("2023-08-08T16:15:07.427Z"), "sampledReadsCount" : NumberLong(2), "sampledWritesCount" : NumberLong(3) }
When run on a mongod --shardsvr that is part of a sharded
cluster:
{ "desc" : "query analyzer", "ns" : "testDb.testColl", "collUuid" : UUID("5130b4df-5966-434f-85f0-f8956b5ca74e"), "startTime" : ISODate("2023-08-08T16:15:07.427Z"), "sampledReadsCount" : NumberLong(2), "sampledReadsBytes" : NumberLong(346), "sampledWritesCount" : NumberLong(3), "sampledWritesBytes" : NumberLong(904) }
Output Fields
Each output document may contain a subset of the following fields, as relevant for the operation:
$currentOp.typeThe type of operation. Values are either:
opidleSessionidleCursor
If the
$currentOp.typeisop,$currentOp.opprovides details on the specific operation.
$currentOp.shardThe name of the shard where the operation is running.
Only present for sharded clusters.
$currentOp.clientThe IP address (or hostname) and the ephemeral port of the client connection where the operation originates.
For multi-document transactions,
$currentOp.clientstores information about the most recent client to run an operation inside the transaction.For standalones and replica sets only
$currentOp.client_sThe IP address (or hostname) and the ephemeral port of the
mongoswhere the operation originates.For sharded clusters only
$currentOp.clientMetadataAdditional information on the client.
For multi-document transactions,
$currentOp.clientstores information about the most recent client to run an operation inside the transaction.
$currentOp.appNameThe identifier of the client application which ran the operation. Use the
appNameconnection string option to set a custom value for theappNamefield.
$currentOp.activeA boolean value specifying whether the operation has started. Value is
trueif the operation has started orfalseif the operation is idle, such as an idle connection, an inactive session, or an internal thread that is currently idle. An operation can be active even if the operation has yielded to another operation.
$currentOp.twoPhaseCommitCoordinatorInformation on either:
The commit coordination metrics for a transaction whose write operations span multiple shards.
Commit coordination is handled by a shard, and
$currentOp(run either on amongosor a shard member) returns a shard's coordination information only for transactions the shard is currently coordinating.To filter for only the commit coordination metrics:
db.getSiblingDB("admin").aggregate( [ { $currentOp: { allUsers: true, idleSessions: true } }, { $match: { desc: "transaction coordinator" } } ] ) A specific commit coordination operation (i.e.
typeisopanddescis"TransactionCoordinator") spawned by the transaction coordinator.
Note
If run with idleSessions: false,
$currentOpdoes not return the$currentOp.twoPhaseCommitCoordinatorinformation ininactivestateIf access control is enabled and allUsers: false,
$currentOpdoes not return$currentOp.twoPhaseCommitCoordinatorinformation.
$currentOp.twoPhaseCommitCoordinator.lsidThe session identifier for the multi-shard transaction.
The combination of the
lsidandtxnNumberidentifies the transaction.Available for both the commit coordination metrics and for specific coordination operation.
$currentOp.twoPhaseCommitCoordinator.txnNumberThe transaction number for the multi-shard transaction.
The combination of the
txnNumberandlsididentifies the transaction.Available for both the commit coordination metrics and for specific coordination operation.
$currentOp.twoPhaseCommitCoordinator.actionThe specific commit coordination operation spawned by the transaction coordinator:
"sendingPrepare""sendingCommit""sendingAbort""writingParticipantList""writingDecision""deletingCoordinatorDoc"
Only available for specific coordination operation.
$currentOp.twoPhaseCommitCoordinator.startTimeThe start date and time of the
action.Only available for specific coordination operation.
$currentOp.twoPhaseCommitCoordinator.numParticipantsNumber of shards participating in this commit.
Only available for the commit coordination metrics.
$currentOp.twoPhaseCommitCoordinator.stateThe current step/state of the commit coordination process.
Step/stageDescriptioninactiveNot actively part of a commit.
writingParticipantListWriting a local record of the list of shards that are part of this multi-shard transaction.
waitingForVotesWaiting for the participants to respond with vote to commit or abort.
writingDecisionWriting a local record of the coordinator's decision to commit or abort based on votes.
waitingForDecisionAckWaiting for participants to acknowledge the coordinator's decision to commit or abort.
deletingCoordinatorDocDeleting the local record of commit decision.
Only available for the commit coordination metrics.
See also
$currentOp.twoPhaseCommitCoordinator.stepDurations.
$currentOp.twoPhaseCommitCoordinator.commitStartTimeThe date and time when the commit started.
Only available for the commit coordination metrics.
$currentOp.twoPhaseCommitCoordinator.hasRecoveredFromFailoverA boolean that indicates whether the commit coordination was restarted due to failover on the shard that is coordinating the commit.
If
hasRecoveredFromFailoveris true, then the times specified in$currentOp.twoPhaseCommitCoordinator.stepDurationsmay not be accurate for all steps.Only available for the commit coordination metrics.
$currentOp.twoPhaseCommitCoordinator.stepDurationsA document that contains the duration, in microseconds, of the completed or in-progress
steps/stateof the active process as well as the cumulative total duration; for example:"stepDurations" : { "writingParticipantListMicros" : NumberLong(17801), "totalCommitDurationMicros" : NumberLong(42488463), "waitingForVotesMicros" : NumberLong(30378502), "writingDecisionMicros" : NumberLong(15015), "waitingForDecisionAcksMicros" : NumberLong(12077145), "deletingCoordinatorDocMicros" : NumberLong(6009) }, If
$currentOp.twoPhaseCommitCoordinator.hasRecoveredFromFailoveris true, then the times specified instepDurationsmay not be accurate for all steps.For a coordinator in an
inactivestate, the document is empty:"stepDurations" : { } Only available for the commit coordination metrics.
$currentOp.twoPhaseCommitCoordinator.decisionA document that contains the commit/abort decision, for example:
For a commit decision:
"decision" : { "decision" : "commit", "commitTimestamp" : Timestamp(1572034669, 3) } For an abort decision:
"decision" : { "decision" : "abort", "abortStatus" : { "code" : 282, "codeName" : "TransactionCoordinatorReachedAbortDecision", "errmsg" : "Transaction exceeded deadline" } }
Only available for the commit coordination metrics.
$currentOp.twoPhaseCommitCoordinator.deadlineThe date and time by which the commit must finish.
Only available for the commit coordination metrics.
$currentOp.effectiveUsersAn array that contains a document for each user associated with the operation. Each user document contains the
username and the authenticationdb.See also:
$currentOp.runByAn array that contains a document for each user who is impersonating the
effectiveUser(s)for the operation. The runBy document contains theusername and the authenticationdb. In general, the impersonating user is the__systemuser; e.g."runBy" : [ { "user" : "__system", "db" : "local" } ]
$currentOp.opidThe identifier for the operation. You can pass this value to
db.killOp()inmongoshto terminate the operation.Warning
Terminate running operations with extreme caution. Only use
db.killOp()to terminate operations initiated by clients and do not terminate internal database operations.
$currentOp.secs_runningThe duration of the operation in seconds. MongoDB calculates this value by subtracting the current time from the start time of the operation.
Only present if the operation is running; i.e. if
activeistrue.
$currentOp.microsecs_runningThe duration of the operation in microseconds. MongoDB calculates this value by subtracting the current time from the start time of the operation.
Only present if the operation is running; i.e. if
activeistrue.
$currentOp.transactionA document that contains multi-document transaction information.
Only present if the operation is part of a transaction:
On a replica set.
On a sharded cluster if
$currentOpis run without localOps:true. The transaction information is per shard.On a sharded cluster if
$currentOpis run with localOps:true. The transaction information is a composite view rather than per shard.
$currentOp.transaction.parametersA document that contains information on multi-document transaction.
Only present if the operation is part of a multi-document transaction.
$currentOp.transaction.parameters.txnNumberThe transaction number.
Only present if the operation is part of a multi-document transaction.
$currentOp.transaction.parameters.autocommitA boolean flag that indicates if autocommit is on for the transaction.
Only present if the operation is part of a multi-document transaction.
$currentOp.transaction.parameters.readConcernThe read concern for the transaction.
Multi-document transactions support read concern
"snapshot","local", and"majority".Only present if the operation is part of a multi-document transaction.
$currentOp.transaction.globalReadTimestampThe timestamp of the snapshot read by the operations in the sharded cluster transaction that uses "snapshot" read concern. For transactions on sharded clusters, the read concern
"snapshot"of the data is synchronized across shards; i.e. other read concerns cannot guarantee that the data is from the same snapshot view across the shards.Only present when run with localOps: true for sharded cluster transactions.
$currentOp.transaction.readTimestampThe timestamp of the snapshot being read by the operations in this transaction
Only present if the operation is part of a multi-document transaction. However, the field is not returned if:
the transaction is on a sharded cluster and uses "snapshot" read concern, and
$currentOpis run with localOps: true.
Instead,
$currentOp.transaction.globalReadTimestampis returned.
$currentOp.transaction.startWallClockTimeThe date and time (with time zone) of the transaction start.
Only present if the operation is part of a multi-document transaction.
$currentOp.transaction.timeOpenMicrosThe duration, in microseconds, for the transaction.
The
timeActiveMicrosvalue added to thetimeInactiveMicrosshould equal thetimeOpenMicros.Only present if the operation is part of a multi-document transaction.
$currentOp.transaction.timeActiveMicrosThe total amount of time that the transaction has been active; i.e. when the transaction had operations running.
The
timeActiveMicrosvalue added to thetimeInactiveMicrosshould equal thetimeOpenMicros.Only present if the operation is part of a multi-document transaction.
$currentOp.transaction.timeInactiveMicrosThe total amount of time that the transaction has been inactive; i.e. when the transaction had no operations running.
The
timeInactiveMicrosvalue added to thetimeActiveMicrosshould equal thetimeOpenMicros.Only present if the operation is part of a multi-document transaction.
$currentOp.transaction.numParticipantsNumber of shards participating in this transaction.
Only present if the operation is part of a transaction on a sharded cluster and
$currentOpis run with localOps: true
$currentOp.transaction.participantsAn array of documents detailing the participating shards in this transaction. Each document contains the name, a flag indicating if the shard acts as the commit coordinator, and a flag indicating if the shard is only involved in read operations for the transaction.
{ "name" : "shardA", "coordinator" : false, "readOnly" : false } Only present if the operation is part of a transaction on a sharded cluster and
$currentOpis run with localOps: true
$currentOp.transaction.numReadOnlyParticipantsNumber of shards only affected by read operations in this transaction.
Only present if the operation is part of a transaction on a sharded cluster and
$currentOpis run with localOps: true
$currentOp.transaction.numNonReadOnlyParticipantsNumber of shards affected by operations other than reads in this transaction.
Only present if the operation is part of a transaction on a sharded cluster and
$currentOpis run with localOps: true
$currentOp.transaction.expiryTimeThe date and time (with time zone) when the transaction will time out and abort.
The
$currentOp.transaction.expiryTimeequals the$currentOp.transaction.startWallClockTime+ thetransactionLifetimeLimitSeconds.For more information, see Runtime Limit for transactions.
Only present if the operation is part of a multi-document transaction.
$currentOp.opA string that identifies the specific operation type. Only present if
$currentOp.typeisop.The possible values are:
"none""update""insert""query""command""getmore""remove""killcursors"
"command"operations include most commands such as thecreateIndexes,aggregate, andfindAndModify."query"operations includefindoperations and OP_QUERY operations.
$currentOp.nsThe namespace the operation targets. A namespace consists of the database name and the collection name concatenated with a dot (
.); that is,"<database>.<collection>".
$currentOp.commandA document containing the full command object associated with this operation.
For example, the following output contains the command object for a
findoperation on a collection nameditemsin a database namedtest:"command" : { "find" : "items", "filter" : { "sku" : 1403978 }, ... "$db" : "test" } The following example output contains the command object for a
getMoreoperation generated by a command with cursor ID19234103609on a collection nameditemsin a database namedtest:"command" : { "getMore" : NumberLong("19234103609"), "collection" : "items", "batchSize" : 10, ... "$db" : "test" }, If the command document exceeds 1 kilobyte, the document has the following form:
"command" : { "$truncated": <string>, "comment": <string> } The
$truncatedfield contains a string summary of the document excluding the document'scommentfield if present. If the summary still exceeds 1 kilobyte then it is further truncated, denoted by an ellipsis (...) at the end of the string.The
commentfield is present if a comment was passed to the operation. A comment may be attached to any database command.
$currentOp.cursorA document that contains the cursor information for
idleCursorandgetmoreoperations; i.e. wheretypeisidleCursororopisgetmore.If reporting on a
getmoreoperation before thegetmorehas accessed its cursor information, thecursorfield is not available.$currentOp.cursor.lastAccessDateThe date and time when the cursor was last used.
If the cursor is actively in use (i.e.
opisgetmoreand thetypeis notidleCursor), thenlastAccessDatereports either the time the previousgetmoreended or the time the cursor was created if this is the firstgetmore.
$currentOp.cursor.noCursorTimeoutThe flag that indicates that the cursor doesn't timeout when idle; i.e. if the cursor has the
noTimeoutoption set.If true, the cursor does not time out when idle.
If false, the cursor times out when idle.
See also:
$currentOp.cursor.tailableThe flag that indicates if the cursor is a tailable cursor for a capped collection. Tailable cursors remain open after the client exhausts the results in the initial cursor.
See also:
$currentOp.cursor.awaitDataThe flag that indicates whether the tailable cursor should temporarily block a
getMorecommand on the cursor while waiting for new data rather than returning no data.For non-tailable cursors, the value is always false.
See also:
$currentOp.cursor.originatingCommandThe
originatingCommandfield contains the full command object (e.g.findoraggregate) which originally created the cursor.
$currentOp.cursor.planSummaryA string that specifies whether the cursor uses a collection scan (
COLLSCAN) or an index scan (IXSCAN { ... }).The
IXSCANalso includes the specification document of the index used.Not available when running with
localOps: trueonmongosor when reporting onidleCursors.
$currentOp.cursor.queryFrameworkNew in version 6.2.
A string that specifies the query framework used to process an operation.
$currentOp.planSummaryA string that specifies whether the cursor uses a collection scan (
COLLSCAN) or an index scan (IXSCAN { ... }).Not available when running with
localOps: trueonmongos.
$currentOp.prepareReadConflictsThe number of times the current operation had to wait for a prepared transaction with a write to commit or abort.
While waiting, the operation continues to hold any necessary locks and storage engine resources.
$currentOp.writeConflictsThe number of times the current operation conflicted with another write operation on the same document.
$currentOp.numYieldsnumYieldsis a counter that reports the number of times the operation has yielded to allow other operations to complete.Typically, operations yield when they need access to data that MongoDB has not yet fully read into memory. This allows other operations that have data in memory to complete quickly while MongoDB reads in data for the yielding operation.
$currentOp.dataThroughputLastSecondAmount of data (in MiB) processed by the
validateoperation in the last second. Only available for avalidateoperation that is currently scanning documents. For example:"msg" : "Validate: scanning documents Validate: scanning documents: 7258/24000 30%", "progress" : { "done" : 7258, "total" : 24000 }, "numYields" : 0, "dataThroughputLastSecond" : 15.576952934265137, "dataThroughputAverage" : 15.375944137573242,
$currentOp.dataThroughputAverageThe average amount of data (in MiB) processed by the
validateoperation. Only available for avalidateoperation that is currently scanning documents. For example:"msg" : "Validate: scanning documents Validate: scanning documents: 7258/24000 30%", "progress" : { "done" : 7258, "total" : 24000 }, "numYields" : 0, "dataThroughputLastSecond" : 15.576952934265137, "dataThroughputAverage" : 15.375944137573242,
$currentOp.waitingForLatchThe
waitingForLatchdocument is only available if the operation is waiting to acquire an internal locking primitive (a.k.a. a latch) or for an internal condition to be met.For example,
"waitingForLatch" : { "timestamp" : ISODate("2020-03-19T23:25:58.412Z"), "captureName" : "FutureResolution", "backtrace" : [ ] // Only if backtrace: true }, Output FieldDescriptiontimestamp
The date and time at which the operation started to wait.
captureName
The internal name of the section where the operation is currently blocked.
backtrace
The callstack, if available. The field is only included if backtrace: true.
$currentOp.locksThe
locksdocument reports the type and mode of locks the operation currently holds. The possible lock types are as follows:Lock TypeDescriptionParallelBatchWriterModeRepresents a lock for parallel batch writer mode.
In earlier versions, PBWM information was reported as part of the
Globallock information.ReplicationStateTransitionRepresents lock taken for replica set member state transitions.
GlobalRepresents global lock.
DatabaseRepresents database lock.
CollectionRepresents collection lock.
MutexRepresents mutex.
MetadataRepresents metadata lock.
oplogRepresents lock on the oplog.
The possible modes are as follows:
Lock ModeDescriptionRRepresents Shared (S) lock.
WRepresents Exclusive (X) lock.
rRepresents Intent Shared (IS) lock.
wRepresents Intent Exclusive (IX) lock.
$currentOp.lockStatsFor each lock type and mode (see
locksfor descriptions of lock types and modes), returns the following information:$currentOp.lockStats.acquireCountNumber of times the operation acquired the lock in the specified mode.
$currentOp.lockStats.acquireWaitCountNumber of times the operation had to wait for the
acquireCountlock acquisitions because the locks were held in a conflicting mode.acquireWaitCountis less than or equal toacquireCount.
$currentOp.lockStats.timeAcquiringMicrosCumulative time in microseconds that the operation had to wait to acquire the locks.
timeAcquiringMicrosdivided byacquireWaitCountgives an approximate average wait time for the particular lock mode.
$currentOp.waitingForLockReturns a boolean value.
waitingForLockistrueif the operation is waiting for a lock andfalseif the operation has the required lock.
$currentOp.msgThe
msgprovides a message that describes the status and progress of the operation. In the case of indexing or mapReduce operations, the field reports the completion percentage.
$currentOp.progressReports on the progress of mapReduce or indexing operations. The
progressfields corresponds to the completion percentage in themsgfield. Theprogressspecifies the following information:
$currentOp.killPendingReturns
trueif the operation is currently flagged for termination. When the operation encounters its next safe termination point, the operation terminates.
$currentOp.waitingForFlowControlA boolean that indicates if the operation had to wait because of flow control.
$currentOp.flowControlStatsThe flow control statistics for this operation.
$currentOp.totalOperationTimeElapsedThe total time elapsed, in seconds, for the current resharding operation. The time is set to 0 when a new resharding operation starts.
Only present if a resharding operation is taking place.
New in version 5.0.
$currentOp.remainingOperationTimeEstimatedThe estimated time remaining in seconds for the current resharding operation. The time is set to -1 when a new resharding operation starts.
Only present when a resharding operation is taking place. This field may not be present if an estimate cannot not be computed.
New in version 5.0.
$currentOp.approxDocumentsToCopyThe approximate number of documents to be copied from the donor shards to the recipient shards during the resharding operation. This number is an estimate that is set at the beginning of the resharding operation and does not change after it has been set. The number is set to 0 when a new resharding operation starts. It is possible for
$currentOp.documentsCopiedand$currentOp.bytesCopiedto end up exceeding$currentOp.approxDocumentsToCopyand$currentOp.approxBytesToCopy, respectively, if the post-resharding data distribution is not perfectly uniform.Only present on a recipient shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.documentsCopiedThe number of documents copied form donor shards to recipient shards during the resharding operation. The number is set to 0 when a new resharding operation starts.
Only present on a recipient shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.approxBytesToCopyThe approximate number of bytes to be copied from the donor shards to the recipient shards during the resharding operation. This number is an estimate that is set at the beginning of the resharding operation and does not change after it has been set. The number is set to 0 when a new resharding operation starts. It is possible for
$currentOp.documentsCopiedand$currentOp.bytesCopiedto end up exceeding$currentOp.approxDocumentsToCopyand$currentOp.approxBytesToCopy, respectively, if the post-resharding data distribution is not perfectly uniform.Only present on a recipient shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.bytesCopiedThe number of bytes copied from donor shards to recipient shards during the resharding operation. The number is set to 0 when a new resharding operation starts.
Only present on a recipient shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.totalCopyTimeElapsedThe total elapsed time, in seconds, for ongoing data copy tasks from donor shards to recipient shards for the current resharding operation. The time is set to 0 when a new resharding operation starts.
Only present on a recipient shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.oplogEntriesFetchedThe number of entries fetched from the oplog for the current resharding operation. The number is set to 0 when a new resharding operation starts.
Only present on a recipient shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.oplogEntriesAppliedThe number of entries applied to the oplog for the current resharding operation. The number is set to 0 when a new resharding operation starts.
Only present on a recipient shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.totalApplyTimeElapsedThe total elapsed time, in seconds, for the apply step of the current resharding operation. In the apply step, recipient shards apply oplog entries to modify their data based on new incoming writes from donor shards. The time is set to 0 when a new resharding operation starts.
Only present on a recipient shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.countWritesDuringCriticalSectionThe number of writes performed in the critical section for the current resharding operation. The critical section prevents new incoming writes to the collection currently being resharded. The number is set to 0 when a new resharding operation starts.
Only present on a donor shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.totalCriticalSectionTimeElapsedThe total elapsed time, in seconds, for the critical section of the current resharding operation. The critical section prevents new incoming writes to the collection currently being resharded. The time is set to 0 when a new resharding operation starts.
Only present on a donor shard when a resharding operation is taking place.
New in version 5.0.
$currentOp.donorStateThe current state of a donor shard for the resharding operation. The state is set to
unusedwhen a new resharding operation starts.Only present on a donor shard when a resharding operation is taking place.
StateDescriptionunusedThe resharding operation is about to start or recovering from a primary failover.
preparing-to-donateThe donor shard is preparing to donate data to the recipient shards.
donating-initial-dataThe donor shard is donating data to the recipient shards.
donating-oplog-entriesThe donor shard is donating oplog entries to the recipient shards.
preparing-to-block-writesThe donor shard is about to prevent new incoming write operations to the collection that is being resharded.
errorAn error occurred during the resharding operation.
blocking-writesThe donor shard is preventing new incoming write operations and the donor shard has notified all recipient shards that new incoming writes are prevented.
doneThe donor shard has dropped the old sharded collection and the resharding operation is complete.
New in version 5.0.
$currentOp.recipientStateThe current state of a recipient shard for a resharding operation. The state is set to
unusedwhen a new resharding operation starts.Only present on a donor shard when a resharding operation is taking place.
StateDescriptionunusedThe resharding operation is about to start or recovering from a primary failover.
awaiting-fetch-timestampThe recipient shard is waiting for the donor shards to be prepared to donate their data.
creating-collectionThe recipient shard is creating the new sharded collection.
cloningThe recipient shard is receiving data from the donor shards.
applyingThe recipient shard is applying oplog entries to modify its copy of the data based on the new incoming writes from donor shards.
errorAn error occurred during the resharding operation.
strict-consistencyThe recipient shard has all data changes stored in a temporary collection.
doneThe resharding operation is complete.
New in version 5.0.
$currentOp.coordinatorStateThe state of the resharding coordinator for the current resharding operation. The resharding coordinator is an operation that runs on the config server primary. The state is set to
unusedwhen a new resharding operation starts.Only present on the coordinating config server.
StateDescriptionunusedThe resharding operation is about to start or recovering from a primary failover.
initializingThe resharding coordinator has inserted the coordinator document into
config.reshardingOperationsand has added thereshardingFieldsto theconfig.collectionsentry for the original collection.preparing-to-donateThe resharding coordinator
has created a
config.collectionsentry for the temporary resharding collection.has inserted entries into
config.chunksfor ranges based on the new shard key.has inserted entries into
config.tagsfor any zones associated with the new shard key.
The coordinator informs participant shards to begin the resharding operation. The coordinator then waits until all donor shards have picked a
minFetchTimestampand are ready to donate.cloningThe resharding coordinator informs donor shards to donate data to recipient shards. The coordinator waits for all recipients to finish cloning the data from the donor.
applyingThe resharding coordinator informs recipient shards to modify their copies of data based on new incoming writes from donor shards. The coordinator waits for all recipients to finish applying oplog entries.
blocking-writesThe resharding coordinator informs donor shards to prevent new incoming write operations to the collection being resharded. The coordinator then waits for all recipients to have all data changes.
abortingAn unrecoverable error occurred during the resharding operation or the
abortReshardCollectioncommand (or thesh.abortReshardCollection()method) was run.committingThe resharding coordinator removes the
config.collectionsentry for the temporary resharding collection. The coordinator then adds therecipientFieldsto the source collection's entry.New in version 5.0.
$currentOp.opStatusThe current state of a resharding operation.
Only present if a resharding operation is taking place. Once the operation has completed, the operation is removed from
currentOpoutput.StateDescriptionactively runningThe resharding operation is actively running.
successThe resharding operation has succeeded.
failureThe resharding operation has failed.
canceledThe resharding operation was canceled.
New in version 5.0.
$currentOp.collUuidThe UUID of the sampled collection.
This field only appears on documents related to query sampling. For details, see Sampled Queries.
New in version 7.0.
$currentOp.startTimeThe time at which query sampling began.
This field only appears on documents related to query sampling. For details, see Sampled Queries.
New in version 7.0.
$currentOp.samplesPerSecondThe maximum number of queries to sample per second.
Only reported when running
$currentOponmongos.This field only appears on documents related to query sampling. For details, see Sampled Queries.
New in version 7.0.
$currentOp.sampledReadsCountThe number of sampled read queries.
This field only appears on documents related to query sampling. For details, see Sampled Queries.
New in version 7.0.
$currentOp.sampledWritesCountThe number of sampled write queries.
This field only appears on documents related to query sampling. For details, see Sampled Queries.
New in version 7.0.
$currentOp.sampledReadsBytesThe size of the sampled read queries, in bytes.
On a replica set, this is reported on every
mongod.On a sharded cluster, this only reported on
mongodwith--shardsvr.This field only appears on documents related to query sampling. For details, see Sampled Queries.
New in version 7.0.
$currentOp.sampledWritesBytesThe size of the sampled write queries, in bytes.
On a replica set, this is reported on every
mongod.On a sharded cluster, this only reported on
mongodwith--shardsvr.This field only appears on documents related to query sampling. For details, see Sampled Queries.
New in version 7.0.