이 기사에서는 MongoDB 실행 계획 보기에 대한 지식을 공유하여 모든 사람에게 도움이 되기를 바랍니다. MongoDB의 explain() 함수를 사용하면 쿼리 관련 정보를 볼 수 있어 검색 병목 현상을 빠르게 찾아 해결할 수 있습니다. 이 기사에서는 explain()의 몇 가지 용도와 쿼리 결과의 의미를 살펴보겠습니다.
1. Linux에 MongoDB 설치
3. MongoDB 데이터 유형
4. MongoDB 문서 쿼리 작업(1)
6. MongoDB 문서 쿼리 연산 (3)
일반적으로 explain()의 사용법은 sort(),limit()의 사용법과 유사하지만, explain()은 맨 마지막에 위치해야 한다는 점이 다릅니다.
db.sang_collect.find({x:1}).explain()
{ "queryPlanner" : { "plannerVersion" : 1, "namespace" : "sang.sang_collect", "indexFilterSet" : false, "parsedQuery" : { "x" : { "$eq" : 1.0 } }, "winningPlan" : { "stage" : "COLLSCAN", "filter" : { "x" : { "$eq" : 1.0 } }, "direction" : "forward" }, "rejectedPlans" : [] }, "serverInfo" : { "host" : "localhost.localdomain", "port" : 27017, "version" : "3.4.9", "gitVersion" : "876ebee8c7dd0e2d992f36a848ff4dc50ee6603e" }, "ok" : 1.0 }반환 결과입니다. 두 가지 큰 정보가 포함되어 있습니다. 하나는 쿼리 계획인 queryPlanner이고 다른 하나는 MongoDB 서비스에 대한 일부 정보인 serverInfo입니다. 여기에 관련된 매개변수가 많으므로 하나씩 살펴보겠습니다. 있다 queryed indexFilterSet
parsedQuery | |
---|---|
winingPlan | 최고의 실행 계획 |
stage입니다. | 쿼리 방법, 공통사항이 있습니다 COLLSCAN/ 전체 테이블 스캔, IXSCAN/인덱스 스캔, 인덱스 기반 문서 FETCH/검색, SHARD_MERGE/샤드 결과 병합, _id |
filter | 필터 조건 |
direction | 검색 방향 |
rejectedPlans | 거부된 실행 계획 |
serverInfo | MongoDB 서버 정보 |
다른 매개변수 추가 | explain()도 다른 매개변수를 설정하여 더 자세한 쿼리 계획을 볼 수 있습니다. |
queryPlanner는 기본 매개변수입니다. queryPlanner 매개변수를 추가한 후의 쿼리 결과는 위에서 본 쿼리 결과이므로 여기서는 자세히 설명하지 않겠습니다. | executionStats |
{ "queryPlanner" : { "plannerVersion" : 1, "namespace" : "sang.sang_collect", "indexFilterSet" : false, "parsedQuery" : {}, "winningPlan" : { "stage" : "COLLSCAN", "direction" : "forward" }, "rejectedPlans" : [] }, "executionStats" : { "executionSuccess" : true, "nReturned" : 10000, "executionTimeMillis" : 4, "totalKeysExamined" : 0, "totalDocsExamined" : 10000, "executionStages" : { "stage" : "COLLSCAN", "nReturned" : 10000, "executionTimeMillisEstimate" : 0, "works" : 10002, "advanced" : 10000, "needTime" : 1, "needYield" : 0, "saveState" : 78, "restoreState" : 78, "isEOF" : 1, "invalidates" : 0, "direction" : "forward", "docsExamined" : 10000 } }, "serverInfo" : { "host" : "localhost.localdomain", "port" : 27017, "version" : "3.4.9", "gitVersion" : "876ebee8c7dd0e2d992f36a848ff4dc50ee6603e" }, "ok" : 1.0 } | 위에서 소개한 일부 매개변수 외에도 다음과 같은 의미를 지닌 ExecutionStats 매개변수도 있습니다. |
매개변수 | 의미 |
totalKeysExamined | |
---|---|
totalDocsExamined | 문서 스캔 횟수 |
executionStages | 이 카테고리는 실행 상태를 설명합니다 |
stage | 스캔 방법, 구체적인 선택값은 위와 같습니다 |
n반환 | 쿼리 결과 개수 |
executionTimeMillisEstimate | 예상 시간 소모 |
works | 작업 단위 수, 쿼리가 작은 작업 단위로 분할됩니다 |
advanced | 반환된 결과 수 first |
docsEx amined | Documentation 검사 횟수는 totalDocsExamined |
allPlansExecution | allPlansExecution을 사용하여 모든 실행 계획을 가져오는 데 사용되며 기본적으로 결과 매개 변수는 위와 동일하므로 생략하겠습니다. 여기에서 자세히 알아보세요. |
관련 권장사항: | |
MongoDB 고정 컬렉션에 대한 자세한 설명 | |
mongodb 데이터베이스 사용 방법에 대한 Laravel 튜토리얼 |