Docs Menu
Docs Home
/
MongoDB 매뉴얼
/ / /

sh.unshardCollection

이 페이지의 내용

  • 정의
  • 구문
  • 호환성
  • 고려 사항
  • 요구 사항:
  • 행동
  • 예시
  • 자세히 알아보기
sh.unshardCollection( namespace, shardID )

기존의 샤딩된 컬렉션 을 언샤드하고 컬렉션 데이터를 단일 샤드 로 이동합니다. 컬렉션 의 샤딩을 해제하면 컬렉션 을 여러 샤드 로 분할할 수 없으며 샤드 키 가 제거됩니다.

버전 8.0에 추가 되었습니다.

중요

Mongo쉬 방법

이 페이지에서는 mongosh 메서드를 설명합니다. 이는 데이터베이스 명령 또는 Node.js와 같은 언어별 드라이버에 대한 설명서가 아닙니다.

데이터베이스 명령에 대해서는 unshardCollection 명령을 참조하십시오.

MongoDB API 드라이버의 경우 언어별 MongoDB 드라이버 설명서를 참조하세요.

sh.unshardCollection 메서드를 사용하려면 컬렉션 데이터를 수신할 샤드 를 지정해야 합니다. unshardCollection 명령을 사용할 때 대상 샤드 를 지정하지 않으면 클러스터 가 자동으로 데이터가 가장 적은 샤드 를 선택합니다.

컬렉션 구역 샤딩 사용하는 경우 컬렉션 샤딩 해제하기 전에 먼저 범위 연결과 샤드 구역 에서 제거 해야 합니다. 자세한 내용은 구역 샤딩 해제를 참조하세요.

참고

컬렉션 의 샤딩 해제는 쓰기 집약적인 작업으로 oplog 성장률이 증가할 수 있습니다. 이를 완화하려면 다음과 같은 구성 변경을 고려하세요.

  • oplog 의 무제한 증가를 방지하려면 고정된 oplog 크기를 설정하다 합니다.

  • 세컨더리가 오래될 가능성을 줄이려면 oplog 크기를 늘리세요.

자세한 내용은 복제본 세트 oplog 를 참조하세요.

sh.unshardCollection 의 구문은 다음과 같습니다:

sh.unshardCollection( namespace, shardID )
Parameter
유형
설명

namespace

문자열

샤딩을 해제할 데이터베이스 및 컬렉션 을 지정합니다.

shardID

문자열

수신자 샤드 ID 를 지정합니다. MongoDB 가 컬렉션 을 샤딩 해제하면 컬렉션 데이터를 현재 샤드에서 이 특정 샤드 로 이동합니다.

이 메서드는 다음 환경에서 호스팅되는 배포에서 사용할 수 있습니다.

  • MongoDB Atlas: 클라우드에서의 MongoDB 배포를 위한 완전 관리형 서비스

중요

이 명령은 공유 또는 서버리스 인스턴스에서 실행 수 없습니다. 자세한 내용은 지원되지 않는 명령을 참조하세요.

  • sh.unshardCollection() 샤딩된 클러스터에서만 실행 수 있습니다.

  • sh.unshardCollection() 샤딩된 컬렉션에서만 작동할 수 있습니다.

  • sh.unshardCollection() 한 번에 하나의 컬렉션 에서만 작동할 수 있습니다.

  • sh.unshardCollection() 최소 지속 시간은 5 분입니다.

  • sh.unshardCollection() 실행 후 Atlas Search 인덱스를 다시 작성해야 합니다.

  • sh.unshardCollection() 이(가) 완료될 때까지 샤드를 추가 또는 제거하거나 내장된 구성 서버와 전용 구성 서버 간에 전환하는 등 토폴로지 를 변경할 수 없습니다.

  • sh.unshardCollection() 이(가) 진행 중인 동안에는 샤딩 해제 중인 컬렉션 에서 다음 작업을 실행 수 없습니다.

  • unshardCollection 이(가) 진행 중인 동안에는 클러스터 에서 다음 작업을 실행 수 없습니다.

  • sh.unshardCollection() 이(가) 진행 중인 동안 발생하는 인덱스 빌드는 자동으로 실패할 수 있습니다.

    • sh.unshardCollection() 이(가) 진행되는 동안에는 인덱스를 생성하지 마세요.

    • 진행 중인 인덱스 빌드가 있는 경우 sh.unshardCollection() 를 호출하지 마세요.

컬렉션 의 샤딩을 해제하기 전에 다음 요구 사항을 충족하는지 확인하세요.

  • 애플리케이션 은 영향을 받는 컬렉션 이 쓰기를 차단하는 2초의 기간을 허용할 수 있습니다. 쓰기가 차단되는 기간 동안 애플리케이션 의 지연 시간 이 증가합니다.

  • 데이터베이스는 다음과 같은 리소스 요구 사항을 충족합니다.

    • 컬렉션 을 이동하려는 샤드 에 컬렉션 및 해당 인덱스를 위한 충분한 저장 공간이 있는지 확인합니다. 대상 샤드 에는 최소 ( Collection storage size + Index Size ) * 2 바이트의 사용 가능한 공간이 필요합니다.

    • I/O 용량 이 50% 미만인지 확인합니다.

    • CPU 로드가 80% 미만인지 확인합니다.

구역 샤딩 사용하는 컬렉션 샤딩 해제하려면 먼저 밸런서 중지한 다음 구역 에서 범위 와 샤드 제거 .

예시 는 구역 샤드 컬렉션 샤딩 해제를 참조하세요.

이 예시 에서는 app 데이터베이스 의 inventory 컬렉션 을 shard02 샤드 로 샤딩 해제합니다.

sh.unshardCollection( "app.inventory", "shard02" )

사용 가능한 샤드 ID 목록을 가져오려면 sh.status() 를 실행 합니다. 자세한 내용은 sh.status() 출력을 참조하세요.

이 예시 구역을 사용하는 컬렉션 샤딩을 해제합니다.

1

밸런서 중지하려면 메서드를 실행 sh.stopBalancer() .

sh.stopBalancer()
2

구역과 연결된 범위를 식별하려면 메서드를 실행 하고 sh.status()chunks 샤딩된 컬렉션 에 대해 필드 의 범위를 기록합니다.

sh.status()
3

구역 에서 범위 제거 하려면 메서드를 sh.removeRangeFromZone() 사용합니다.

sh.removeRangeFromZone( {
"app.inventory",
{ size: 100 },
{ size: 500 }
} )

컬렉션 에서 사용하는 구역에서 모든 범위를 제거할 때까지 이 단계를 반복합니다.

4

구역 에서 샤드 제거 하려면 메서드를 실행 sh.removeShardFromZone() .

sh.removeShardFromZone( "shard01", "mid" )

모든 구역에서 샤드 제거할 때까지 반복합니다.

5

밸런서 다시 시작하려면 메서드를 실행 sh.startBalancer() .

sh.startBalancer()
6

컬렉션 샤딩을 해제하려면 sh.unshardCollection 메서드를 실행 .

sh.unshardCollection( "app.inventory", "shard01" )

돌아가기

sh.stopBalancer