Docs Menu
Docs Home
/
MongoDB Ops Manager
/ / /

리뷰 지수 순위

이 페이지의 내용

  • Performance Advisor가 인덱스를 제안하고 순위를 매기는 방법
  • 인덱스 필드 순서
  • 제안된 인덱스 제한
  • 예시: 뉴욕시택시 데이터

Performance Advisor 에서 제안하는 인덱스 는 해당 Impact 점수를 기준으로 정렬됩니다. Impact 는 제안된 인덱스 가 가져올 수 있는 예상 성능 향상을 나타냅니다.

Performance Advisor는 실행 시간이 100 밀리초 이상인 쿼리를 모니터링하고 이러한 쿼리를 일반적인 쿼리 형태 로 그룹화합니다. Performance Advisor는 형태와 일치하는 쿼리에서 다음과 같이 집계된 메트릭을 고려하여 각 쿼리 형태의 비효율성을 계산합니다.

  • 쿼리 실행에 소요된 시간입니다.

  • 스캔한 문서 수입니다.

  • 반환된 문서 수입니다.

권장 인덱스를 설정하기 위해 Performance Advisor는 수식에서 이러한 지표를 사용하여 Impact 또는 해당 쿼리 형태와 일치하는 인덱스를 생성하면 발생할 수 있는 성능 향상을 계산합니다. Performance Advisor는 인덱스별 작업을 실행하는 데 소요된 시간을 배포서버의 총 운영 지연 시간과 비교합니다. Performance Advisor가 인덱스를 제안하면 인덱스는 Impact 점수를 기준으로 순위가 매겨집니다.

쿼리 형태의 쿼리 작업 유형은 인덱스를 구성하는 데 사용되는 필드의 순서에 영향을 줍니다. 일반적으로 필드는 카디널리티를 기준으로 순위가 매겨집니다.

다음 표는 Performance Advisor가 다양한 작업 유형의 상대적 중요도를 순서대로 순위를 매기는 방법을 보여줍니다.

순위
작업 유형
연산자 예시

1

동등성 매치

2

배열 쿼리

3

범위 쿼리

4

유형 쿼리

5

Exists

6

기타 모든 연산자

7

Sort

Performance Advisor 는 다음과 같은 인덱스를 제안하지 않습니다.

  • 필드가 16 개 이상인 경우 및/또는

  • 필드 키로 _id 를 포함합니다.

또한 Performance Advisor 는 다음과 같은 경우에만 인덱스 를 제안합니다.

  • 영향을 받는 쿼리의 경우 스캔한 문서와 반환된 문서의 차이가 500 보다 큽니다.

  • 지난 24 시간 동안 영향을 받는 쿼리를 실행하는 데 누적으로 최소 60 초 이상이 소요되었습니다.

Performance Advisor 는 제안하기 전에 겹치는 인덱스의 중복을 제거합니다. 예를 예시 Performance Advisor 가 다음과 같은 잠재적인 추천 인덱스를 계산한다고 가정해 보겠습니다.

{ a : 1 }
{ a : 1, b : 1 }

{ a : 1 } 이(가) { a : 1, b : 1 } 의 접두사이므로 Performance Advisor 는 { a : 1, b : 1 } 만 제안합니다. 인덱스 접두사에 대한 자세한 내용은 접두사를 참조하세요 .

이 예에서는 뉴욕시 택시 이용에 대한 정보가 포함된 cab-db 데이터베이스를 사용하며, 여기에는 승차 및 하차 시간, 승차 거리, 승차 비용 내역에 대한 필드가 포함되어 있습니다. 컬렉션 yellow 의 일반적인 문서는 다음과 같습니다.

{
"_id" : ObjectId("5db9daab0b2a17b7706cd6a3"),
"pickup_datetime" : "2014-06-30 02:09:23",
"dropoff_datetime" : "2014-06-30 02:20:36",
"passenger_count" : 2,
"trip_distance" : 3,
"fare_amount" : 12,
"tip_amount" : 2.6,
"total_amount" : 15.6
}

컬렉션에는 10 백만 개 이상의 문서가 포함되어 있으므로 특정 필드 데이터를 기반으로 쿼리를 실행해야 하는 애플리케이션은 컬렉션을 올바르게 인덱싱하지 않으면 매우 비효율적인 작업을 생성할 수 있습니다.

이 애플리케이션 에 대한 일반적인 쿼리는 하나 이상의 다른 필드와 결합된 특정 드롭오프 시간이 포함된 문서를 검색 합니다. 예를 예시 다음과 같습니다.

db.yellow.find({ "dropoff_datetime": "2014-06-19 21:45:00",
"passenger_count": 1,
"trip_distance": {"$gt": 3 }
})

Performance Advisor는 성능 향상을 위해 다음 인덱스를 권장합니다.

추천 인덱스 스크린샷
클릭하여 확대

참고

기본적으로 Performance Advisor는 클러스터의 모든 컬렉션에 대한 인덱스 권장 사항을 표시합니다. 권장 사항 범위를 특정 컬렉션으로 좁히려면 Collection 드롭다운 메뉴에서 컬렉션을 선택합니다.

권장 인덱스는 성능에 영향 이 가장 큰 것부터 가장 적은 것 순으로 나열되어 있습니다. 이 예시 에서 첫 번째 권장 인덱스 는 전체 클러스터 작업 지연 시간 시간을 50% 줄이는 것으로 추정됩니다.

첫 번째 권장 사항은 세 필드에 대한 인덱스입니다.

  • passenger_count

  • dropoff_datetime

  • trip_distance

Create Index 버튼을 클릭하여 원하는 추가 옵션이 포함된 인덱스 를 생성합니다. Performance Advisor 에서 인덱스 를 만드는 방법에 학습 보려면 추천 인덱스 만들기를 참조하세요.

이 인덱스 를 만들면 데이터베이스 엔진 이 쿼리 와 일치하는 문서를 찾기 위해 전체 컬렉션 을 스캔할 필요가 없으므로 성능이 향상됩니다. 예시 에 표시된 모양의 쿼리는 인덱싱된 컬렉션 에서 50 밀리초 이하의 결과를 반환하지만, 인덱싱되지 않은 컬렉션 에서는 몇 초가 소요됩니다.

돌아가기

느린 쿼리 임계값 구성