operação atual
Nesta página
Definição
currentOp
Descontinuado desde a versão 6.2.
Nas versões 6.2 e posterior, utilize o estágio de agregação
$currentOp
.Retorna um documento que contém informações sobre operações em andamento para a instância do
mongod
.Use o estágio de agregação
$currentOp
em vez do comandocurrentOp
e seu método auxiliarmongosh
db.currentOp()
.
Compatibilidade
Esse comando está disponível em implantações hospedadas nos seguintes ambientes:
MongoDB Atlas: o serviço totalmente gerenciado para implantações do MongoDB na nuvem
Observação
Este comando é aceito em todos os clusters do MongoDB Atlas. Para obter informações sobre o suporte do Atlas para todos os comandos, consulte Comandos sem suporte.
MongoDB Enterprise: a versão autogerenciada e baseada em assinatura do MongoDB
MongoDB Community: uma versão com código disponível, de uso gratuito e autogerenciada do MongoDB
Sintaxe
O comando tem a seguinte sintaxe:
db.adminCommand( { currentOp: 1 } )
Observação
A partir do MongoDB 5.0, o estágio de agregação $currentOp
é usado ao executar o método auxiliar db.currentOp()
com mongosh
.
Diante disso, na versão 5.0 do shell e com mongosh, os conjuntos de resultados de db.currentOp()
não estão sujeitos ao limite do tamanho de retorno de documento BSON de 16 MB para documentos das versões anteriores do mongo
herdado.
Comportamento
currentOp
deve ser executado no banco de dados admin
e pode aceitar vários campos opcionais.
Campo | Descrição |
---|---|
"$ownOps" | Booleano. Se definido para Em instâncias do |
"$all" | Booleano. Se definido para
|
<filter> | Especifique as condições de filtro nos Campos de Saída. Veja exemplos. |
comment | Opcional. Um comentário fornecido pelo usuário para anexar a este comando. Depois de definido, esse comentário aparece junto com os registros desse comando nos seguintes locais:
Um comentário pode ser qualquer tipo BSON válido (string, inteiro, objeto, array etc). |
currentOp
e o analisador de banco de dados relatam as mesmas informações de diagnóstico básicas para operações CRUD, incluindo o seguinte:
getMore
(OP_GET_MORE ecommand
)
Essas operações também são incluídas no logging de queries lentas. Consulte slowOpThresholdMs
para obter mais informações sobre registro de queries lentas.
Redação
Ao usar Queryable Encryption, as operações currentOp
com a opção encryptionInformation
suprimem determinadas informações:
A saída omite todos os campos após
"command"
.A saída edita
"command"
para incluir apenas o primeiro elemento$comment
e$db
.
Controle de acesso
Em sistemas executados com authorization
, o usuário deve ter acesso que inclua a ação de privilégio inprog
.
Os usuários podem utilizar o $ownOps
em instâncias do mongod
para visualizar suas próprias operações sem a ação de privilégio do inprog
.
db.adminCommand( { currentOp: 1, "$ownOps": 1 } )
Exemplos
Os exemplos seguintes utilizam o comando currentOp
com vários documentos de query para filtrar a saída.
Exibir todas as operações atuais
db.adminCommand( { currentOp: true, "$all": true } )
Operações de gravação aguardando um bloqueio
O exemplo a seguir retorna informações sobre todas as operações de gravação que estão aguardando um bloqueio:
db.adminCommand( { currentOp: true, "waitingForLock" : true, $or: [ { "op" : { "$in" : [ "insert", "update", "remove" ] } }, { "command.findandmodify": { $exists: true } } ] } )
Operações ativas sem rendimento
O exemplo a seguir retorna informações sobre todas as operações em execução ativas que nunca produziram:
db.adminCommand( { currentOp: true, "active" : true, "numYields" : 0, "waitingForLock" : false } )
Operações ativas em um banco de dados específico
O exemplo a seguir retorna informações sobre todas as operações ativas do banco de dados db1
que estão em execução há mais de 3 segundos:
db.adminCommand( { currentOp: true, "active" : true, "secs_running" : { "$gt" : 3 }, "ns" : /^db1\./ } )
Operações de indexação ativas
O exemplo a seguir retorna informações sobre operações de criação de índice:
db.adminCommand( { currentOp: true, $or: [ { op: "command", "command.createIndexes": { $exists: true } }, { op: "none", "msg" : /^Index Build/ } ] } )
Exemplo de saída
Confira a seguir um protótipo da saída currentOp
quando executado em um sistema autônomo:
{ "inprog": [ { "type" : <string>, "host" : <string>, "desc" : <string>, "connectionId" : <number>, "client" : <string>, "appName" : <string>, "clientMetadata" : <document>, "active" : <boolean>, "currentOpTime" : <string>, "effectiveUsers" : [ { "user" : <string>, "db" : <string> } ], "opid" : <number>, "lsid" : { "id" : <UUID>, "uid" : <BinData> }, "secs_running" : <NumberLong()>, "microsecs_running" : <number>, "op" : <string>, "ns" : <string>, "command" : <document>, "queryFramework" : <string>, "planSummary": <string>, "cursor" : { // only for getMore operations "cursorId" : <NumberLong()>, "createdDate" : <ISODate()>, "lastAccessDate" : <ISODate()>, "nDocsReturned" : <NumberLong()>, "nBatchesReturned" : <NumberLong()>, "noCursorTimeout" : <boolean>, "tailable" : <boolean>, "awaitData" : <boolean>, "originatingCommand" : <document>, "planSummary" : <string>, "operationUsingCursorId" : <NumberLong()> }, "msg": <string>, "progress" : { "done" : <number>, "total" : <number> }, "killPending" : <boolean>, "numYields" : <number>, "dataThroughputLastSecond" : <number>, "dataThroughputAverage" : <number>, "locks" : { "ParallelBatchWriterMode" : <string>, "ReplicationStateTransition" : <string>, "Global" : <string>, "Database" : <string>, "Collection" : <string>, "Metadata" : <string>, "oplog" : <string> }, "waitingForLock" : <boolean>, "lockStats" : { "ParallelBatchWriterMode" : { "acquireCount": { "r": <NumberLong>, "w": <NumberLong>, "R": <NumberLong>, "W": <NumberLong> }, "acquireWaitCount": { "r": <NumberLong>, "w": <NumberLong>, "R": <NumberLong>, "W": <NumberLong> }, "timeAcquiringMicros" : { "r" : NumberLong(0), "w" : NumberLong(0), "R" : NumberLong(0), "W" : NumberLong(0) }, "deadlockCount" : { "r" : NumberLong(0), "w" : NumberLong(0), "R" : NumberLong(0), "W" : NumberLong(0) } }, "ReplicationStateTransition" : { ... }, "Global": { ... }, "Database" : { ... }, ... } }, ... ], "fsyncLock": <boolean>, "info": <string>, "ok": <num> }
Confira a seguir um protótipo da saída currentOp
quando executado em um primário de um conjunto de réplicas:
{ "inprog": [ { "type" : <string>, "host" : <string>, "desc" : <string>, "connectionId" : <number>, "client" : <string>, "appName" : <string>, "clientMetadata" : <document>, "lsid" : { "id" : <UUID>, "uid" : <BinData> }, "transaction" : { "parameters" : { "txnNumber" : <NumberLong()>, "autocommit" : <boolean>, "readConcern" : { "level" : <string> } }, "readTimestamp" : <Timestamp>, "startWallClockTime" : <string>, "timeOpenMicros" : <NumberLong()>, "timeActiveMicros" : <NumberLong()>, "timeInactiveMicros" : <NumberLong()>, "expiryTime" : <string>, }, "active" : <boolean>, "currentOpTime" : <string>, "effectiveUsers" : [ { "user" : <string>, "db" : <string> } ], "opid" : <number>, "secs_running" : <NumberLong()>, "microsecs_running" : <number>, "op" : <string>, "ns" : <string>, "command" : <document>, "originatingCommand" : <document>, "queryFramework" : <string>, "planSummary": <string>, "prepareReadConflicts" : <NumberLong()>, "writeConflicts" : <NumberLong()>, "cursor" : { // only for getMore operations "cursorId" : <NumberLong()>, "createdDate" : <ISODate()>, "lastAccessDate" : <ISODate()>, "nDocsReturned" : <NumberLong()>, "nBatchesReturned" : <NumberLong()>, "noCursorTimeout" : <boolean>, "tailable" : <boolean>, "awaitData" : <boolean>, "originatingCommand" : <document>, "planSummary" : <string>, "operationUsingCursorId" : <NumberLong()> }, "msg": <string>, "progress" : { "done" : <number>, "total" : <number> }, "killPending" : <boolean>, "numYields" : <number>, "dataThroughputLastSecond" : <number>, "dataThroughputAverage" : <number>, "locks" : { "ParallelBatchWriterMode" : <string>, "ReplicationStateTransition" : <string>, "Global" : <string>, "Database" : <string>, "Collection" : <string>, "Metadata" : <string>, "oplog" : <string> }, "waitingForLock" : <boolean>, "lockStats" : { "ParallelBatchWriterMode" : { "acquireCount": { "r": <NumberLong>, "w": <NumberLong>, "R": <NumberLong>, "W": <NumberLong> }, "acquireWaitCount": { "r": <NumberLong>, "w": <NumberLong>, "R": <NumberLong>, "W": <NumberLong> }, "timeAcquiringMicros" : { "r" : NumberLong(0), "w" : NumberLong(0), "R" : NumberLong(0), "W" : NumberLong(0) }, "deadlockCount" : { "r" : NumberLong(0), "w" : NumberLong(0), "R" : NumberLong(0), "W" : NumberLong(0) } }, "ReplicationStateTransition" : { ... }, "Global" : { ... }, "Database" : { ... }, ... } }, ... ], "fsyncLock": <boolean>, "info": <string>, "ok": <num>, "operationTime": <timestamp>, "$clusterTime": <document> }
O seguinte é um exemplo da saída currentOp
quando executado em um mongos
de um cluster fragmentado (os campos podem variar dependendo da operação que está sendo relatada):
{ "inprog": [ { "shard": <string>, "type" : <string>, "host" : <string>, "desc" : <string>, "connectionId" : <number>, "client_s" : <string>, "appName" : <string>, "clientMetadata" : <document>, "lsid" : { "id" : <UUID>, "uid" : <BinData> }, "transaction" : { "parameters" : { "txnNumber" : <NumberLong()>, "autocommit" : <boolean>, "readConcern" : { "level" : <string> } }, "readTimestamp" : <Timestamp>, "startWallClockTime" : <string>, "timeOpenMicros" : <NumberLong()>, "timeActiveMicros" : <NumberLong()>, "timeInactiveMicros" : <NumberLong()>, "expiryTime" : <string>, }, "active" : <boolean>, "currentOpTime" : <string>, "effectiveUsers" : [ { "user" : <string>, "db" : <string> } ], "runBy" : [ { "user" : <string>, "db" : <string> } ], "twoPhaseCommitCoordinator" : { "lsid" : { "id" : <UUID>, "uid" : <BinData> }, "txnNumber" : <NumberLong>, "numParticipants" : <NumberLong>, "state" : <string>, "commitStartTime" : <ISODate>, "hasRecoveredFromFailover" : <boolean>, "stepDurations" : <document>, "decision" : <document>, "deadline" : <ISODate> } "opid" : <string>, "secs_running" : <NumberLong()>, "microsecs_running" : <number>, "op" : <string>, "ns" : <string>, "command" : <document>, "configTime" : <Timestamp>, // Starting in 5.0 "topologyTime" : <Timestamp>, // Starting in 5.0 "queryFramework" : <string>, // Starting in 6.2 "planSummary": <string>, "prepareReadConflicts" : <NumberLong()>, "writeConflicts" : <NumberLong()>, "cursor" : { // only for getMore operations "cursorId" : <NumberLong()>, "createdDate" : <ISODate()>, "lastAccessDate" : <ISODate()>, "nDocsReturned" : <NumberLong()>, "nBatchesReturned" : <NumberLong()>, "noCursorTimeout" : <boolean>, "tailable" : <boolean>, "awaitData" : <boolean>, "originatingCommand" : <document>, "planSummary" : <string>, "operationUsingCursorId" : <NumberLong()> }, "msg": <string>, "progress" : { "done" : <number>, "total" : <number> }, "killPending" : <boolean>, "numYields" : <number>, "dataThroughputLastSecond" : <number>, "dataThroughputAverage" : <number>, "locks" : { "ParallelBatchWriterMode" : <string>, "ReplicationStateTransition" : <string>, "Global" : <string>, "Database" : <string>, "Collection" : <string>, "Metadata" : <string>, "DDLDatabase" : <string>, "DDLCollection" : <string>, "oplog" : <string> }, "waitingForLock" : <boolean>, "lockStats" : { "ParallelBatchWriterMode": { "acquireCount": { "r": <NumberLong>, "w": <NumberLong>, "R": <NumberLong>, "W": <NumberLong> }, "acquireWaitCount": { "r": <NumberLong>, "w": <NumberLong>, "R": <NumberLong>, "W": <NumberLong> }, "timeAcquiringMicros" : { "r" : NumberLong(0), "w" : NumberLong(0), "R" : NumberLong(0), "W" : NumberLong(0) }, "deadlockCount" : { "r" : NumberLong(0), "w" : NumberLong(0), "R" : NumberLong(0), "W" : NumberLong(0) } }, "ReplicationStateTransition" : { ... }, "Global" : { ... }, "Database" : { ... }, ... } }, ... ], "ok": <num>, "operationTime": <timestamp>, "$clusterTime": <document> }
Exemplos de saída específicos
Estas amostras de saída ilustram currentOp
saída para operações específicas. Os campos que compõem a saída real variam dependendo do papel do servidor.
Exemplo de saída de refragmentação
{ type: "op", desc: "Resharding{Donor, Recipient, Coordinator}Service <reshardingUUID>", op: "command", ns: "<database>.<collection>", originatingCommand: { reshardCollection: "<database>.<collection>", key: <shardkey>, unique: <boolean>, collation: {locale: "simple"}, // Other options to the reshardCollection command are omitted // to decrease the likelihood the output is truncated. }, {donor, coordinator, recipient}State : "<service state>", approxDocumentsToCopy: NumberLong(<count>), approxBytesToCopy: NumberLong(<count>), bytesCopied: NumberLong(<count>), countWritesToStashCollections: NumberLong(<count>), countWritesDuringCriticalSection : NumberLong(<count>), countReadsDuringCriticalSection: NumberLong(<count>), deletesApplied: NumberLong(<count>), documentsCopied: NumberLong(<count>), insertsApplied: NumberLong(<count>), oplogEntriesFetched: NumberLong(<count>), oplogEntriesApplied: NumberLong(<count>), remainingOperationTimeEstimatedSecs: NumberLong(<count>), allShardsLowestRemainingOperationTimeEstimatedSecs: NumberLong(<estimate>), allShardsHighestRemainingOperationTimeEstimatedSecs: NumberLong(<estimate>), totalApplyTimeElapsedSecs: NumberLong(<count>), totalCopyTimeElapsedSecs: NumberLong(<count>), totalCriticalSectionTimeElapsedSecs : NumberLong(<count>), totalOperationTimeElapsedSecs: NumberLong(<count>), updatesApplied: NumberLong(<count>), }
Exemplo de índice global
{ type: "op", desc: "GlobalIndex{Donor, Recipient, Coordinator}Service <globalIndexUUID}", op: "command", ns: "<database>.<collection>", originatingCommand: { createIndexes: "<database>.<collection>", key: <indexkeypattern>, unique: <boolean>, <Additional createIndexes options> }, {donor, coordinator, recipient}State : "<service state>", approxDocumentsToScan: NumberLong(<count>), approxBytesToScan: NumberLong(<count>), bytesWrittenFromScan: NumberLong(<count>), countWritesToStashCollections: NumberLong(<count>), countWritesDuringCriticalSection : NumberLong(<count>), countReadsDuringCriticalSection: NumberLong(<count>), keysWrittenFromScan: NumberLong(<count>), remainingOperationTimeEstimatedSecs: NumberLong(<count>), allShardsLowestRemainingOperationTimeEstimatedSecs: NumberLong(<estimate>), allShardsHighestRemainingOperationTimeEstimatedSecs: NumberLong(<estimate>), totalCopyTimeElapsedSecs: NumberLong(<count>), totalCriticalSectionTimeElapsedSecs : NumberLong(<count>), totalOperationTimeElapsedSecs: NumberLong(<count>), }
Campos de Saída
currentOp.type
O tipo de operação. Os valores são:
op
idleSession
idleCursor
Se o
currentOp.type
forop
, ocurrentOp.op
fornecerá detalhes sobre a operação específica.
currentOp.desc
Uma descrição do cliente. Esta string inclui o
connectionId
.
currentOp.client
Uma string com informações sobre a origem da operação.
Para transações com vários documentos,
client
armazena informações sobre o cliente mais recente para executar uma operação dentro da transação.
currentOp.appName
O identificador do aplicativo cliente que executou a operação. Use uma opção
appName
de connection string para definir um valor personalizado para o campoappName
.
currentOp.clientMetadata
Informações adicionais sobre o cliente.
Para transações com vários documentos,
client
armazena informações sobre o cliente mais recente para executar uma operação dentro da transação.
currentOp.currentQueue
Novidades na versão 8.0.
A fila atual da operação.
currentOp.currentQueue.name
O nome da fila atual da operação.
Observação
Se
currentQueue
estiver presente ename
foringress
, a operação estará aguardando a entrada de ingresso.
currentOp.queues
Informações sobre as filas
ingress
eexecution
da operação atual.
currentOp.effectiveUsers
Uma array que contém um documento para cada usuário associado à operação. Cada documento de usuário contém o nome
user
e a autenticaçãodb
.
currentOp.runBy
Uma array que contém um documento para cada usuário que está personificando
effectiveUser(s)
para a operação. O documento runBy contém o nomeuser
e a autenticaçãodb
. Em geral, o usuário do runBy é o usuário__system
; por exemplo,"runBy" : [ { "user" : "__system", "db" : "local" } ] Disponível apenas em clusters fragmentados
currentOp.lsid
O identificador da sessão.
Somente presente se a operação estiver associada a uma sessão.
currentOp.transaction
Um documento que contém informações de transação multidocumento.
Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.parameters
Um documento que contém informações sobre transações com vários documentos.
Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.parameters.txnNumber
O número da transação.
Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.parameters.autocommit
Uma bandeira booleana que indica se o envio automático está ativado para a transação.
Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.parameters.readConcern
A read concern com a transação.
As transações com vários documentos são compatíveis com read concern
"snapshot"
,"local"
e"majority"
.Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.readTimestamp
O carimbo de data/hora do snapshot que está sendo lido pelas operações na transação.
Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.startWallClockTime
A data e hora (com fuso horário) do início da transação.
Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.timeOpenMicros
A duração da transação em microssegundos.
O valor
timeActiveMicros
adicionado aotimeInactiveMicros
deve ser igual aotimeOpenMicros
.Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.timeActiveMicros
A quantidade total de tempo em que a transação esteve ativa; ou seja, quando a transação teve operações em execução.
O valor
timeActiveMicros
adicionado aotimeInactiveMicros
deve ser igual aotimeOpenMicros
.Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.timeInactiveMicros
O tempo total em que a transação ficou inativa; ou seja, quando a transação não tinha operações em execução.
O valor
timeInactiveMicros
adicionado aotimeActiveMicros
deve ser igual aotimeOpenMicros
.Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.transaction.expiryTime
A data e a hora (com fuso horário) em que a transação irá expirar e cancelar.
O
currentOp.transaction.expiryTime
é igual aocurrentOp.transaction.startWallClockTime
+ otransactionLifetimeLimitSeconds
.Para obter mais informações, consulte o Limite de tempo de execução para transações.
Somente presente se a operação fizer parte de uma transação multidocumento.
currentOp.twoPhaseCommitCoordinator
Informações sobre:
As métricas de coordenação de cometimento para uma transação cujas operações de gravação abrangem vários shards.
A coordenação de confirmação é tratada por um shard e
currentOp
(executado em ummongos
ou um membro do shard) retorna as informações de coordenação de um shard somente para as transações atualmente coordenadas por esse shard.Para filtrar apenas as métricas de coordenação de confirmação:
db.currentOp( { desc: "transaction coordinator" }) Uma operação de coordenação de confirmação específica (ou seja,
currentOp.type
éop
ecurrentOp.desc
é"TransactionCoordinator"
) gerados pelo coordenador de transações.
currentOp.twoPhaseCommitCoordinator.lsid
O identificador da sessão para a transação com vários fragmentos.
A combinação de
lsid
etxnNumber
identifica a transação.Disponível tanto para as métricas de coordenação de confirmação quanto para a operação de coordenaçãoespecífica .
currentOp.twoPhaseCommitCoordinator.txnNumber
O número da transação para a transação multi-shard.
A combinação de
txnNumber
elsid
identifica a transação.Disponível tanto para as métricas de coordenação de confirmação quanto para a operação de coordenaçãoespecífica .
currentOp.twoPhaseCommitCoordinator.action
A operação de coordenação de cometimento específica gerada pelo coordenador de transações:
"sendingPrepare"
"sendingCommit"
"sendingAbort"
"writingParticipantList"
"writingDecision"
"deletingCoordinatorDoc"
Disponível apenas para operação de coordenaçãoespecífica.
currentOp.twoPhaseCommitCoordinator.startTime
A data e hora de início do
action
.Disponível apenas para operação de coordenaçãoespecífica.
currentOp.twoPhaseCommitCoordinator.numParticipants
Número de fragmentos participantes neste commit.
Disponível somente para as métricas de coordenação de confirmação.
currentOp.twoPhaseCommitCoordinator.state
A etapa/estado atual do processo de coordenação de commit.
Etapa/estágioDescriçãoinactive
Não faz parte ativamente de um commit.writingParticipantList
Escrevendo um registro local da lista de fragmentos que fazem parte dessa transação com vários fragmentos.waitingForVotes
Aguardando que os participantes respondam com voto para confirmar ou cancelar.writingDecision
Escrevendo um registro local da decisão do coordenador de cometer ou cancelar com base em votos.waitingForDecisionAck
Aguardando que os participantes reconheçam a decisão do coordenador de cometer ou cancelar.deletingCoordinatorDoc
Excluindo o registro local da decisão de commit.Disponível somente para as métricas de coordenação de confirmação.
Consulte também
currentOp.twoPhaseCommitCoordinator.stepDurations
.
currentOp.twoPhaseCommitCoordinator.commitStartTime
A data e a hora em que o commit começou.
Disponível somente para as métricas de coordenação de confirmação.
currentOp.twoPhaseCommitCoordinator.hasRecoveredFromFailover
Um booleano que indica se a coordenação de commit foi reiniciada devido ao failover no fragmento que está coordenando o commit.
Se
hasRecoveredFromFailover
for verdadeiro, então os horários especificados emcurrentOp.twoPhaseCommitCoordinator.stepDurations
podem não ser precisos em todas as etapas.Disponível somente para as métricas de coordenação de confirmação.
currentOp.twoPhaseCommitCoordinator.stepDurations
Um documento que contém a duração, em microssegundos, da coordenação de confirmação
steps/state
concluída ou em andamento:"stepDurations" : { "writingParticipantListMicros" : NumberLong(17801), "totalCommitDurationMicros" : NumberLong(42488463), "waitingForVotesMicros" : NumberLong(30378502), "writingDecisionMicros" : NumberLong(15015), "waitingForDecisionAcksMicros" : NumberLong(12077145), "deletingCoordinatorDocMicros" : NumberLong(6009) }, Se
currentOp.twoPhaseCommitCoordinator.hasRecoveredFromFailover
for verdadeiro, então os horários especificados emstepDurations
podem não ser precisos em todas as etapas.Para um coordenador em um estado
inactive
, o documento está vazio:"stepDurations" : { } Disponível somente para as métricas de coordenação de confirmação.
currentOp.twoPhaseCommitCoordinator.decision
Um documento que contém a decisão de cometer/abortar, por exemplo:
Para uma decisão de cometimento:
"decision" : { "decision" : "commit", "commitTimestamp" : Timestamp(1572034669, 3) } Para uma decisão de cancelamento:
"decision" : { "decision" : "abort", "abortStatus" : { "code" : 282, "codeName" : "TransactionCoordinatorReachedAbortDecision", "errmsg" : "Transaction exceeded deadline" } }
Disponível somente para as métricas de coordenação de confirmação.
currentOp.twoPhaseCommitCoordinator.deadline
A data e a hora em que o commit deve terminar.
Disponível somente para as métricas de coordenação de confirmação.
currentOp.opid
O identificador da operação. Você pode passar esse valor para
db.killOp()
emmongosh
para encerrar a operação.Aviso
Encerre as operações em execução com extrema cautela. Use apenas
db.killOp()
para encerrar operações iniciadas por clientes e não encerre operações internas de banco de dados.
currentOp.active
Um valor booleano especificando se a operação começou. O valor é
true
se a operação foi iniciada oufalse
se a operação está ociosa, como uma conexão ociosa ou um thread interno que esteja ocioso no momento. Uma operação pode estar ativa mesmo que tenha cedido preferência a outra operação. Para alguns tópicos inativos em segundo plano, como umsignalProcessingThread
inativo, o MongoDB suprime vários campos vazios.
currentOp.secs_running
A duração da operação em segundos. O MongoDB calcula este valor subtraindo o tempo atual da hora de início da operação.
Só aparece quando a operação estiver em execução; ou seja, se
active
étrue
.
currentOp.microsecs_running
A duração da operação em microssegundos. O MongoDB calcula este valor subtraindo o tempo atual da hora de início da operação.
Só aparece quando a operação estiver em execução; ou seja, se
active
étrue
.
currentOp.op
Uma string que identifica o tipo de operação específico. Presente somente se
currentOp.type
forop
.Os valores possíveis são:
"none"
"update"
"insert"
"query"
"command"
"getmore"
"remove"
"killcursors"
"query"
operações incluem operações de leitura."command"
As operações incluem a maioria dos comandos, comocreateIndexes
efindAndModify
.
currentOp.ns
O namespace que a operação tem como alvo. Um namespace consiste no nome do banco de dados e o nome da coleção concatenado com um ponto (
.
); isto é,"<database>.<collection>"
.
currentOp.command
Um documento contendo o objeto de comando completo associado a esta operação.
Por exemplo, a seguinte saída contém o objeto de comando para uma operação
find
em uma collection denominadaitems
em um banco de dados denominadotest
:"command" : { "find" : "items", "filter" : { "sku" : 1403978 }, ... "$db" : "test" } O seguinte exemplo de saída contém o objeto de comando para uma operação
getMore
gerada por um comando com ID de cursor19234103609
em uma collection denominadaitems
em um banco de dados denominadotest
:"command" : { "getMore" : NumberLong("19234103609"), "collection" : "items", "batchSize" : 10, ... "$db" : "test" }, Se o documento de comando exceder 1 kilobyte, o documento terá o seguinte formulário:
"command" : { "$truncated": <string>, "comment": <string> } O campo
$truncated
contém um resumo de strings do documento, excluindo o campocomment
do documento, se presente. Se, mesmo assim, o resumo exceder 1 kilobyte, ele será ainda mais truncado, indicado por uma reticência (...) no final da string.O campo
comment
está presente se algum comentário foi passado para a operação. Um comentário pode ser anexado a qualquer comando de banco de dados.
currentOp.planSummary
Especifica se o cursor utiliza um exame de collection (
COLLSCAN
) ou uma verificação de índice (IXSCAN { ... }
).O
IXSCAN
também inclui o documento de especificação do índice utilizado.
currentOp.prepareReadConflicts
O número de vezes que a operação atual precisou aguardar uma transação preparada com uma gravação para cometer ou abortar.
Enquanto aguarda, a operação atual continua mantendo todas as travas e recursos de mecanismo de armazenamento necessários.
currentOp.writeConflicts
O número de vezes que a operação atual entrou em conflito com outra operação de gravação no mesmo documento.
currentOp.cursor
Um documento que contém as informações do cursor para operações
getmore
; ou seja, ondeop
égetmore
.Se estiver relatando uma operação
getmore
antes que ogetmore
tenha acessado as informações do cursor, o campocursor
não estará disponível.currentOp.cursor.noCursorTimeout
O sinalizador que indica que o cursor não expira quando ocioso; ou seja, quando o cursor tem a opção
noTimeout
definida.Se verdadeiro, o cursor não expira quando ocioso.
Se falso, o cursor expira quando ocioso.
currentOp.cursor.tailable
O sinalizador que indica se o cursor é um cursor caudal para uma coleção limitada. Os cursores de ocorrências permanecem abertos após o cliente esgotar os resultados no cursor inicial.
currentOp.cursor.awaitData
O sinalizador que indica se o cursor tailable deve bloquear temporariamente um comando
getMore
no cursor enquanto aguarda novos dados, em vez de retornar nenhum dado.Para cursores não rastreáveis, o valor é sempre falso.
currentOp.cursor.originatingCommand
O campo
originatingCommand
contém o objeto de comando completo (por exemplo,find
ouaggregate
) que originalmente criou o cursor.
currentOp.locks
O documento
locks
relata o tipo e o modo de bloqueios que a operação mantém atualmente. Os possíveis tipos de bloqueio são os seguintes:Bloquear tipoDescriçãoParallelBatchWriterMode
Representa um bloqueio para o modo de escrita em lote paralelo.
Em versões anteriores, as informações do PBWM foram relatadas como parte das informações de bloqueio do
Global
.ReplicationStateTransition
Representa o bloqueio obtido para transições de estado membro do conjunto de réplicas.Global
Representa bloqueio global.Database
Representa bloqueio de banco de dados.Collection
Representa bloqueio de coleção.Mutex
Representa mutex.Metadata
Representa bloqueio de metadados.DDLDatabase
Representa um reconhecimento de data center DDL .
Novidade na versão 7.1.
DDLCollection
Representa um bloqueio de collection DDL .
Novidade na versão 7.1.
oplog
Representa bloqueio no oplog.Veja os modos possíveis:
Modo de bloqueioDescriçãoR
Representa bloqueio compartilhado (S).W
Representa bloqueio exclusivo (X).r
Representa bloqueio de Intent Shared (IS).w
Representa bloqueio Intent Exclusive (IX).
currentOp.admissionPriority
Para uso interno. O valor é a prioridade que uma operação tem ao tentar adquirir um ticket para realizar uma ação do mecanismo de armazenamento.
Os valores possíveis são: "baixo", "normal" e "imediato". Somente operações com um valor "baixo" são relatadas.
Exemplo de saída
currentOp
:{ type: 'op', host: 'ip-10-122-5-147:27017', desc: 'JournalFlusher', active: true, currentOpTime: '2022-10-11T12:45:52.053+00:00', opid: 201, op: 'none', ns: '', command: {}, numYields: 0, admissionPriority: 'low', locks: {}, waitingForLock: false, lockStats: {}, waitingForFlowControl: false, flowControlStats: {} } O valor
admissionPriority
também é relatado no registro lento.Novidades na versão 6.3.
currentOp.waitingForLock
Retorna um valor booleano.
waitingForLock
serátrue
se a operação estiver aguardando um bloqueio efalse
se a operação tiver o bloqueio necessário.
currentOp.msg
O
msg
fornece uma mensagem que descreve o status e o progresso da operação. No caso de indexar ou mapReduzir operações, o campo relata a porcentagem de conclusão.
currentOp.progress
Relatórios sobre o progresso de mapReduce ou operações de indexação. Os campos
progress
correspondem à porcentagem de conclusão no campomsg
. Oprogress
especifica as seguintes informações:
currentOp.killPending
Retorna
true
se a operação estiver sinalizada para encerramento. Quando encontra seu próximo ponto de encerramento seguro, a operação termina.
currentOp.numYields
numYields
é um contador que relata o número de vezes que a operação rendeu para permitir que outras operações sejam concluídas.Normalmente, as operações são realizadas quando precisam acessar dados que o MongoDB ainda não leu completamente na memória. Isso permite que outras operações que tenham dados na memória sejam concluídas rapidamente enquanto o MongoDB lê os dados para a operação de produção.
currentOp.dataThroughputLastSecond
Quantidade de dados (em MiB) processados pela operação
validate
no último segundo. Disponível somente para uma operaçãovalidate
que esteja digitalizando documentos no momento. Por exemplo:"msg" : "Validate: scanning documents Validate: scanning documents: 7258/24000 30%", "progress" : { "done" : 7258, "total" : 24000 }, "numYields" : 0, "dataThroughputLastSecond" : 15.576952934265137, "dataThroughputAverage" : 15.375944137573242,
currentOp.dataThroughputAverage
A quantidade média de dados (em MiB) processados pela operação
validate
. Disponível somente para uma operaçãovalidate
que esteja digitalizando documentos no momento. Por exemplo:"msg" : "Validate: scanning documents Validate: scanning documents: 7258/24000 30%", "progress" : { "done" : 7258, "total" : 24000 }, "numYields" : 0, "dataThroughputLastSecond" : 15.576952934265137, "dataThroughputAverage" : 15.375944137573242,
currentOp.fsyncLock
Especifica se o banco de dados está bloqueado para
fsync write/snapshot
.Aparece apenas se estiver bloqueado; ou seja, se
fsyncLock
fortrue
.
currentOp.info
Informações sobre como desbloquear banco de dados do
db.fsyncLock()
. Só aparece sefsyncLock
fortrue
.
currentOp.lockStats
Para cada tipo e modo de bloqueio (consulte
currentOp.locks
para obter descrições de tipos e modos de bloqueio), retorna as seguintes informações:currentOp.lockStats.acquireCount
Número de vezes que a operação adquiriu a trava no modo especificado.
currentOp.lockStats.acquireWaitCount
Número de vezes que a operação teve que esperar pelas aquisições de bloqueio
acquireCount
porque os bloqueios foram mantidos em modo conflitante.acquireWaitCount
é menor ou igual aacquireCount
.
currentOp.lockStats.timeAcquiringMicros
Tempo cumulativo em microssegundos que a operação teve que esperar para adquirir as travas.
timeAcquiringMicros
dividido poracquireWaitCount
fornece um tempo médio aproximado de espera para o modo de bloqueio específico.
currentOp.waitingForFlowControl
Um booleano que indica se a operação está em processo de espera pelo controle de fluxo.
currentOp.flowControlStats
As estatísticas de controle de fluxo desta operação.
currentOp.totalOperationTimeElapsedSecs
O tempo total decorrido, em segundos, para a operação de refragmentação atual. O tempo é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente somente se uma operação de refragmentação estiver ocorrendo.
Novidades na versão 5.0.
A partir do MongoDB 6.1, essa métrica também está disponível no coordenador durante a refragmentação.
currentOp.updatesApplied
O número de atualizações aplicadas.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 6.1.
currentOp.remainingOperationTimeEstimatedSecs
remainingOperationTimeEstimatedSecs
: tempo restante estimado em segundos para a operação de refragmentação atual. É retornado como-1
quando uma nova operação de refragmentação é iniciada.Começando no:
MongoDB 5.0, mas antes do MongoDB 6.1, o
remainingOperationTimeEstimatedSecs
só está disponível em um shard de receptor durante uma operação de refragmentação.MongoDB 6.1,
remainingOperationTimeEstimatedSecs
também está disponível no coordenador durante uma operação de refragmentação.
A operação de refragmentação executa estas fases na ordem:
A fase do clonagem duplica os dados da collection atual.
A fase de atualização aplica quaisquer operações de gravação pendentes à collection refragmentada.
remainingOperationTimeEstimatedSecs
está definido para uma estimativa de tempo pessimista:A estimativa de tempo da fase de recuperação é definida como o tempo da fase de clonagem, que é um tempo relativamente longo.
Na prática, se houver apenas algumas operações de escrita pendentes, o tempo de fase de recuperação real é relativamente curto.
Novidades na versão 5.0.
currentOp.allShardsLowestRemainingOperationTimeEstimatedSecs
Calculada em todos os shards, é a estimativa mais baixa do número de segundos restantes.
Presente apenas em um coordenador quando uma operação de refragmentação está em andamento.
Novidades na versão 6.1.
currentOp.allShardsHighestRemainingOperationTimeEstimatedSecs
Calculada em todos os shards, é a estimativa mais alta do número de segundos restantes.
Presente apenas em um coordenador quando uma operação de refragmentação está em andamento.
Novidades na versão 6.1.
currentOp.approxDocumentsToCopy
O número aproximado de documentos a serem copiados dos shards do doador para os shards do destinatário durante a operação de refragmentação. Esse número é uma estimativa que é definida no início da operação de refragmentação e não muda depois de definida. O número é definido como 0 quando uma nova operação de refragmentação é iniciada. É possível que
$currentOp.documentsCopied
e$currentOp.bytesCopied
acabem excedendo$currentOp.approxDocumentsToCopy
e$currentOp.approxBytesToCopy
, respectivamente, se a distribuição de dados após a refragmentação não for perfeitamente uniforme.Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
currentOp.documentsCopied
O número de documentos copiados de shards de doador para shards de destinatários durante a operação de refragmentação. O número é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
currentOp.approxBytesToCopy
O número aproximado de bytes a serem copiados dos shards do doador para os do destinatário durante a operação de refragmentação. Esse número é uma estimativa que é definida no início da operação de refragmentação e não muda depois de definida. O número é definido como 0 quando uma nova operação de refragmentação é iniciada. É possível que
$currentOp.documentsCopied
e$currentOp.bytesCopied
acabem excedendo$currentOp.approxDocumentsToCopy
e$currentOp.approxBytesToCopy
, respectivamente, se a distribuição de dados após a refragmentação não for perfeitamente uniforme.Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
currentOp.bytesCopied
O número de bytes copiados dos shards doadores para os shards receptores durante a operação de refragmentação. O número é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
currentOp.countWritesToStashCollections
O número de escritas nas collections de estoque do destinatário.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 6.1.
currentOp.countWritesDuringCriticalSection
O número de tentativas de escrita durante a seção crítica do doador.
Presente apenas em um shard de doador quando uma operação de refragmentação está ocorrendo.
Novidades na versão 6.1.
currentOp.countReadsDuringCriticalSection
O número de tentativas de leitura durante a seção crítica do doador.
Presente apenas em um shard de doador quando uma operação de refragmentação está ocorrendo.
Novidades na versão 6.1.
currentOp.deletesApplied
O número de exclusões aplicadas à collection de refragmentação temporária. Cada entrada de oplog que envolve uma exclusão incrementa o contador em 1.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 6.1.
currentOp.insertsApplied
O número de inserções aplicadas à collection de refragmentação temporária. Cada entrada do oplog que envolve uma inserção incrementa o contador em 1.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 6.1.
currentOp.totalCopyTimeElapsedSecs
O tempo total decorrido, em segundos, para tarefas contínuas de cópia de dados de shards do doador para shards do destinatário para a operação de atualização atual. O tempo é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
A partir do MongoDB 6.1, essa métrica também está disponível no coordenador durante a refragmentação.
currentOp.oplogEntriesFetched
O número de entradas obtidas do oplog para a operação de refragmentação atual. O número é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
currentOp.oplogEntriesApplied
O número de entradas aplicadas ao oplog para a operação de refragmentação atual. O número é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
currentOp.totalApplyTimeElapsedSecs
O tempo total decorrido, em segundos, para a etapa de aplicação da operação de atualização atual. Na etapa de aplicação, os fragmentos do destinatário aplicam entradas de oplog para modificar seus dados com base em novos registros recebidos de fragmentos do doador. O tempo é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente somente em um fragmento destinatário quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
A partir do MongoDB 6.1, essa métrica também está disponível no coordenador durante a refragmentação.
currentOp.countWritesDuringCriticalSection
O número de gravações realizadas na seção crítica para a operação de refragmentação atual. A seção crítica evita novas gravações recebidas na collection que está sendo refragmentada. O número é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente apenas em um shard de doador quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
currentOp.totalCriticalSectionTimeElapsedSecs
O tempo total decorrido, em segundos, para a seção crítica da operação de refragmentação atual. A seção crítica evita novas gravações recebidas na collection sendo refragmentada. O tempo é definido como 0 quando uma nova operação de refragmentação é iniciada.
Presente apenas em um shard de doador quando uma operação de refragmentação está ocorrendo.
Novidades na versão 5.0.
A partir do MongoDB 6.1, essa métrica também está disponível no coordenador durante a refragmentação.
currentOp.donorState
O estado atual de um shard doador para a operação de refragmentação. O estado é definido como
unused
quando uma nova operação de refragmentação é iniciada.Presente apenas em um shard de doador quando uma operação de refragmentação está ocorrendo.
EstadoDescriçãounused
A operação de refragmentação está prestes a ser iniciada ou se recuperando de um failover primário.preparing-to-donate
O shard do doador está se preparando para doar dados para os shards do destinatário.donating-initial-data
O shard do doador está doando dados para os shards do destinatário.donating-oplog-entries
O shard do doador está doando entradas do oplog para os shards do destinatário.preparing-to-block-writes
O shard do doador está prestes a impedir a entrada de novas operações de gravação na collection que está sendo refragmentada.error
Ocorreu um erro durante a operação de refragmentação.blocking-writes
O shard do doador está evitando novas operações de escrita recebidas e o shard do doador notificou todos os shards do destinatário de que novas gravações recebidas são evitadas.done
O shard do doador descartou a collection fragmentada antiga e a operação de refragmentação foi concluída.Novidades na versão 5.0.
currentOp.recipientState
O estado atual de um shard destinatário para uma operação de refragmentação. O estado é definido como
unused
quando uma nova operação de refragmentação é iniciada.Presente apenas em um shard de doador quando uma operação de refragmentação está ocorrendo.
EstadoDescriçãounused
A operação de refragmentação está prestes a ser iniciada ou se recuperando de um failover primário.awaiting-fetch-timestamp
O shard do destinatário está esperando que os shards do doador estejam preparados para doar seus dados.creating-collection
O shard do destinatário está criando a nova collection fragmentada.cloning
O shard do destinatário está recebendo dados dos shards do doador.applying
O shard do destinatário está aplicando entradas do oplog para modificar sua cópia dos dados com base nas novas gravações recebidas dos shards do doador.error
Ocorreu um erro durante a operação de refragmentação.strict-consistency
O shard do destinatário tem todas as alterações de dados armazenadas em uma collection temporária.done
A operação de refragmentação foi concluída.Novidades na versão 5.0.
currentOp.coordinatorState
O estado do coordenador de refragmentação para a operação de refragmentação atual. O coordenador de refragmentação é uma operação executada no servidor de configuração primary. O estado é definido como
unused
quando uma nova operação de refragmentação é iniciada.Presente somente no servidor de configuração de coordenação.
EstadoDescriçãounused
A operação de refragmentação está prestes a ser iniciada ou se recuperando de um failover primário.initializing
O coordenador de refragmentação inseriu o documento do coordenador noconfig.reshardingOperations
e adicionou oreshardingFields
à entradaconfig.collections
para a collection original.preparing-to-donate
O coordenador de refragmentação
criou uma entrada
config.collections
para a collection de refragmentação temporária.inseriu entradas em
config.chunks
para faixas baseadas na nova chave de shard.inseriu entradas em
config.tags
para quaisquer zonas associadas à nova chave de shard.
O coordenador informa aos shards participantes para que iniciem a operação de refragmentação. O coordenador então aguarda até que todos os shards doadores tenham escolhido um
minFetchTimestamp
e estejam prontos para doar.cloning
O coordenador de refragmentação informa os shards do doador para doar dados aos shards do destinatário. O coordenador espera que todos os destinatários terminem de clonar os dados do doador.applying
O coordenador de refragmentação informa aos shards do destinatário que modifiquem suas cópias dos dados com base nas novas gravações recebidas dos shards do doador. O coordenador espera que todos os destinatários terminem de aplicar as entradas do oplog.blocking-writes
O coordenador de refragmentação informa os shards doadores para impedir novas operações de gravação de entrada na collection que está sendo redistribuída. O coordenador então espera que todos os destinatários tenham todas as alterações de dados.aborting
Ocorreu um erro irrecuperável durante a operação de refragmentação ou o comandoabortReshardCollection
(ou o métodosh.abortReshardCollection()
) foi executado.committing
O coordenador de refragmentação remove a entradaconfig.collections
para a collection de refragmentação temporária. O coordenador então adiciona orecipientFields
à entrada da collection de origem.Novidades na versão 5.0.
currentOp.collUuid
O UUID da coleção amostrada.
Este campo só aparece em documentos relacionados à amostragem de query. Para obter detalhes, consulte Queries de amostra.
Novidades na versão 7.0.
currentOp.startTime
A hora em que a amostragem de query começou.
Este campo só aparece em documentos relacionados à amostragem de query. Para obter detalhes, consulte Queries de amostra.
Novidades na versão 7.0.
currentOp.samplesPerSecond
O número máximo de queries a serem amostradas por segundo.
Em um cluster fragmentado, isso é relatado em
mongos
em vez demongod
. Em um conjunto de réplicas, isso é relatado emmongod
.Este campo só aparece em documentos relacionados à amostragem de query. Para obter detalhes, consulte Queries de amostra.
Novidades na versão 7.0.
currentOp.sampledReadsCount
O número de amostras de queries de leitura.
Este campo só aparece em documentos relacionados à amostragem de query. Para obter detalhes, consulte Queries de amostra.
Novidades na versão 7.0.
currentOp.sampledWritesCount
O número de queries de escrita como amostras.
Este campo só aparece em documentos relacionados à amostragem de query. Para obter detalhes, consulte Queries de amostra.
Novidades na versão 7.0.
currentOp.sampledReadsBytes
O tamanho das amostras de queries de leitura, em bytes.
Em um conjunto de réplicas, isso é relatado a cada
mongod
.Em um cluster fragmentado, isso só foi relatado em
mongod
com--shardsvr
.Este campo só aparece em documentos relacionados à amostragem de query. Para obter detalhes, consulte Queries de amostra.
Novidades na versão 7.0.
currentOp.sampledWritesBytes
Tamanho total das queries de escrita amostradas, em bytes.
Em um conjunto de réplicas, isso é relatado a cada
mongod
.Em um cluster fragmentado, isso só foi relatado em
mongod
com--shardsvr
.Este campo só aparece em documentos relacionados à amostragem de query. Para obter detalhes, consulte Queries de amostra.
Novidades na versão 7.0.