정의
- db.currentOp()
- 데이터베이스 인스턴스 의 진행 중인 작업에 대한 정보가 포함된 문서 반환합니다. - db.currentOp()메서드는 데이터베이스 명령- currentOp를 래핑합니다.- 참고- MongoDB 5.0부터 - $currentOp집계 단계는- mongosh로 헬퍼 메서드- db.currentOp()를 실행할 때 사용됩니다.- 이를 감안할 때 셸의 5.0 버전 및 mongosh의 경우 - db.currentOp()결과 세트에는 이전 레거시- mongo버전의 문서에 대한 16MB BSON 문서 반환 크기 문서 반환 크기 제한이 적용되지 않습니다.
호환성
이 메서드는 다음 환경에서 호스팅되는 배포에서 사용할 수 있습니다.
- MongoDB Atlas: 클라우드에서의 MongoDB 배포를 위한 완전 관리형 서비스 
중요
이 명령은 M0 및 Flex 클러스터에서 지원되지 않습니다. 자세한 내용은 지원되지 않는 명령을 참조하세요.
- MongoDB Enterprise: MongoDB의 구독 기반 자체 관리 버전 
- MongoDB Community: MongoDB의 소스 사용 가능 무료 자체 관리 버전 
구문
db.currentOp() 의 형식은 다음과 같습니다.
db.currentOp(<operations>) 
db.currentOp()는 다음과 같은 선택적 인수를 사용할 수 있습니다.
행동
db.currentOp() 는 필터 문서 또는 부울 매개변수를 받을 수 있습니다.
필터 문서를 db.currentOp()로 전달하면 출력은 필터와 일치하는 현재 작업에 대한 정보만 반환합니다. 필터 문서에는 다음이 포함될 수 있습니다.
| 필드 | 설명 | 
|---|---|
| 
 | 부울.  사용자는 언제든지  | 
| 
 | 부울.  문서  | 
| <filter> | 출력 필드 에 필터하다 조건을 지정합니다. 예제를 참조하세요. 문서  | 
db.currentOp()에 true를 전달하는 것은 { "$all": true }의 문서를 전달하는 것과 같습니다. 다음 작업은 이에 해당합니다.
db.currentOp(true) db.currentOp( { "$all": true } ) 
db.currentOp() 및 데이터베이스 프로파일러는 다음을 포함하여 모든 CRUD 작업에 대해 동일한 기본 진단 정보를 보고합니다.
- getMore(OP_GET_MORE 및- command)
이러한 작업은 느린 쿼리 로깅에도 포함됩니다. 느린 쿼리 로깅에 대한 자세한 내용은 slowOpThresholdMs를 참조하세요.
액세스 제어
authorization로 실행되는 시스템에서는 사용자에게 inprog 권한 작업이 포함된 액세스 권한이 있어야 합니다.
사용자는 inprog 권한 작업 없이도 mongod 인스턴스에서 db.currentOp( { "$ownOps": true }
)를 실행하여 자신의 작업을 볼 수 있습니다.
예시
다음 예시에서는 db.currentOp() 메서드를 다양한 쿼리 문서와 함께 사용하여 출력을 필터링합니다.
잠금을 기다리는 쓰기 작업
버전 3.6에서 변경됨.
다음 예에서는 잠금을 기다리는 모든 쓰기 작업에 대한 정보를 반환합니다.
db.currentOp(    {      "waitingForLock" : true,      $or: [         { "op" : { "$in" : [ "insert", "update", "remove" ] } },         { "command.findandmodify": { $exists: true } }     ]    } ) 
양보가 없는 활성 작업
다음 예시에서는 결코 양보되지 않은 모든 활성 실행 작업에 대한 정보를 반환합니다.
db.currentOp(    {      "active" : true,      "numYields" : 0,      "waitingForLock" : false    } ) 
특정 데이터베이스에 대한 활성 작업
다음 예시에서는 3초 이상 실행된 데이터베이스 db1의 모든 활성 작업에 대한 정보를 반환합니다.
db.currentOp(    {      "active" : true,      "secs_running" : { "$gt" : 3 },      "ns" : /^db1\./    } ) 
활성 인덱싱 작업
버전 3.6에서 변경됨.
다음 예시에서는 인덱스 생성 작업에 대한 정보를 반환합니다.
db.adminCommand(     {       currentOp: true,       $or: [         { op: "command", "command.createIndexes": { $exists: true }  },         { op: "none", "msg" : /^Index Build/ }       ]     } ) 
출력 예시
다음은 db.currentOp() 출력의 프로토타입입니다.
다음은 독립형에서 실행될 때의 currentOp 출력의 프로토타입입니다.
{   "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" : <Long()>,          "microsecs_running" : <number>,          "op" : <string>,          "ns" : <string>,          "command" : <document>,          "planSummary": <string>,          "cursor" : {                              // only for getMore operations             "cursorId" : <Long()>,             "createdDate" : <ISODate()>,             "lastAccessDate" : <ISODate()>,             "nDocsReturned" : <Long()>,             "nBatchesReturned" : <Long()>,             "noCursorTimeout" : <boolean>,             "tailable" : <boolean>,             "awaitData" : <boolean>,             "originatingCommand" : <document>,             "planSummary" : <string>,             "operationUsingCursorId" : <Long()>          },          "msg": <string>,          "progress" : {              "done" : <number>,              "total" : <number>          },          "killPending" : <boolean>,          "numYields" : <number>,          "dataThroughputLastSecond" : <number>,          "dataThroughputAverage" : <number>,          "waitingForLatch" : {              "timestamp" : <ISODate()>,              "captureName" : <string>          },          "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" : Long(0),                    "w" : Long(0),                    "R" : Long(0),                    "W" : Long(0)                 },                 "deadlockCount" : {                    "r" : Long(0),                    "w" : Long(0),                    "R" : Long(0),                    "W" : Long(0)                 }              },              "ReplicationStateTransition" : {                 ...              },              "Global": {                 ...              },              "Database" : {                 ...              },              ...          }        },        ...    ],    "fsyncLock": <boolean>,    "info": <string>,     "ok": <num> } 
다음은 복제본 세트의 프라이머리에서 실행되는 currentOp 출력의 프로토타입입니다.
{   "inprog": [        {          "type" : <string>,          "host" : <string>,          "desc" : <string>,          "connectionId" : <number>,          "client" : <string>,          "appName" : <string>,          "clientMetadata" : <document>,          "lsid" : {             "id" : <UUID>,             "uid" : <BinData>          },          "transaction" : {             "parameters" : {                "txnNumber" : <Long()>,                "autocommit" : <boolean>,                "readConcern" : {                   "level" : <string>                }             },             "readTimestamp" : <Timestamp>,             "startWallClockTime" : <string>,             "timeOpenMicros" : <Long()>,             "timeActiveMicros" : <Long()>,             "timeInactiveMicros" : <Long()>,             "expiryTime" : <string>,          },          "active" : <boolean>,          "currentOpTime" : <string>,          "effectiveUsers" : [             {                "user" : <string>,                "db" : <string>             }          ],          "opid" : <number>,          "secs_running" : <Long()>,          "microsecs_running" : <number>,          "op" : <string>,          "ns" : <string>,          "command" : <document>,          "originatingCommand" : <document>,          "planSummary": <string>,          "prepareReadConflicts" : <Long()>,          "writeConflicts" : <Long()>,          "cursor" : {                              // only for getMore operations             "cursorId" : <Long()>,             "createdDate" : <ISODate()>,             "lastAccessDate" : <ISODate()>,             "nDocsReturned" : <Long()>,             "nBatchesReturned" : <Long()>,             "noCursorTimeout" : <boolean>,             "tailable" : <boolean>,             "awaitData" : <boolean>,             "originatingCommand" : <document>,             "planSummary" : <string>,             "operationUsingCursorId" : <Long()>          },          "msg": <string>,          "progress" : {              "done" : <number>,              "total" : <number>          },          "killPending" : <boolean>,          "numYields" : <number>,          "dataThroughputLastSecond" : <number>,          "dataThroughputAverage" : <number>,          "waitingForLatch" : {               "timestamp" : <ISODate()>,               "captureName" : <string>           },          "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" : Long(0),                    "w" : Long(0),                    "R" : Long(0),                    "W" : Long(0)                 },                 "deadlockCount" : {                    "r" : Long(0),                    "w" : Long(0),                    "R" : Long(0),                    "W" : Long(0)                 }              },              "ReplicationStateTransition" : {                 ...              },              "Global" : {                 ...              },              "Database" : {                 ...              },              ...          }        },        ...    ],    "fsyncLock": <boolean>,    "info": <string>,    "ok": <num>,    "operationTime": <timestamp>,    "$clusterTime": <document> } 
다음은 샤딩된 클러스터의 mongos에서 실행할 때 currentOp 출력의 예입니다(필드는 보고되는 작업에 따라 다를 수 있음).
{   "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" : <Long()>,                "autocommit" : <boolean>,                "readConcern" : {                   "level" : <string>                }             },             "readTimestamp" : <Timestamp>,             "startWallClockTime" : <string>,             "timeOpenMicros" : <Long()>,             "timeActiveMicros" : <Long()>,             "timeInactiveMicros" : <Long()>,             "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" : <Long()>,          "microsecs_running" : <number>,          "op" : <string>,          "ns" : <string>,          "command" : <document>,          "configTime" : <Timestamp>,           // Starting in 5.0          "topologyTime" : <Timestamp>,           // Starting in 5.0          "planSummary": <string>,          "prepareReadConflicts" : <Long()>,          "writeConflicts" : <Long()>,          "cursor" : {                              // only for getMore operations             "cursorId" : <Long()>,             "createdDate" : <ISODate()>,             "lastAccessDate" : <ISODate()>,             "nDocsReturned" : <Long()>,             "nBatchesReturned" : <Long()>,             "noCursorTimeout" : <boolean>,             "tailable" : <boolean>,             "awaitData" : <boolean>,             "originatingCommand" : <document>,             "planSummary" : <string>,             "operationUsingCursorId" : <Long()>          },          "msg": <string>,          "progress" : {              "done" : <number>,              "total" : <number>          },          "killPending" : <boolean>,          "numYields" : <number>,          "dataThroughputLastSecond" : <number>,          "dataThroughputAverage" : <number>,          "waitingForLatch" : {              "timestamp" : <ISODate()>,              "captureName" : <string>          },          "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" : Long(0),                    "w" : Long(0),                    "R" : Long(0),                    "W" : Long(0)                 },                 "deadlockCount" : {                    "r" : Long(0),                    "w" : Long(0),                    "R" : Long(0),                    "W" : Long(0)                 }              },              "ReplicationStateTransition" : {                 ...              },              "Global" : {                 ...              },              "Database" : {                 ...              },              ...          }        },        ...    ],   "ok": <num>,   "operationTime": <timestamp>,   "$clusterTime": <document> } 
출력 필드
db.currentOp() 출력 필드의 전체 목록은 currentOp를 참조하세요.