5.0 복제본 세트를 4.4로 다운그레이드
다운그레이드를 시도하기 전에 이 문서의 내용을 숙지하세요.
다운그레이드 경로
중요
복제본 세트를 업그레이드하거나 다운그레이드하기 전에 모든 복제본 세트 멤버가 실행 중인지 확인하세요. 그렇지 않으면 모든 구성원이 시작될 때까지 업그레이드 또는 다운그레이드가 완료되지 않습니다.
5.0에서 다운그레이드해야 하는 경우 최신 패치 릴리스인 4.4로 다운그레이드합니다.
MongoDB는 단일 버전 다운그레이드만 지원합니다. 현재 릴리스보다 이전 버전인 릴리스로 다운그레이드할 수 없습니다.
예를 들어, 5.0 시리즈를 4.4 시리즈 배포로 다운그레이드할 수 있습니다. 하지만 4.4 시리즈 배포를 4.2 시리즈 배포로 한 단계 더 다운그레이드하는 것은 지원되지 않습니다.
백업 생성
선택 사항이지만 권장됩니다. 데이터베이스의 백업을 만듭니다.
액세스 제어
복제본 세트 에 액세스 제어가 활성화되어 있는 경우 다운그레이드 사용자 권한에 데이터베이스 전체에서 인덱스를 나열하고 관리 있는 권한이 포함되어야 합니다. root
역할 을 가진 사용자에게는 필요한 권한이 있습니다.
전제 조건
5.0에서 4.4로 다운그레이드하려면 지속되고 호환되지 않는 기능을 제거하거나 호환되지 않는 구성 설정을 업데이트해야 합니다. 여기에는 다음이 포함됩니다.
1. 클러스터 기본 읽기 및 쓰기 고려
MongoDB 5.0에서는 클러스터 전체 읽기 및 쓰기 고려 기본값이 변경되었으며, MongoDB 4.4로 다운그레이드하면 이러한 기본값이 다시 변경될 수 있습니다. 다운그레이드하기 전에 클러스터의 기본 읽기 및 쓰기 고려를 수동으로 구성하는 것이 좋습니다.
클러스터의 읽기 또는 쓰기 고려에 대한 기본값을 수동으로 구성하려면
setDefaultRWConcern
명령을 사용합니다.클러스터에 중재자가 포함되어 있고 특정 상황에서 캐시 압력을 방지하기 위해 이전에
"Majority"
읽기 고려를 비활성화했다면, 다운그레이드 후--enableMajorityReadConcern false
또는replication.enableMajorityReadConcern: false
를 구성할 수 있습니다.
2. 또는 .
$
문자가 포함된 문서 필드
MongoDB 5.0은 문서 필드 이름에 .
또는 $
문자를 포함하는 기능을 지원합니다. MongoDB 4.4로 다운그레이드하기 전에 .
또는 $
문자가 포함된 필드 이름이 포함된 문서를 모두 삭제해야 합니다.
3. 슬림형 시간대 데이터 파일
MongoDB 5.0은 슬림형 시간대 데이터 파일을 지원합니다. --timeZoneInfo
명령줄 옵션 또는 processManagement.timeZoneInfo
구성 파일 설정으로 MongoDB에 제공된 대로 배포에서 슬림형 시간대 데이터 파일을 사용하는 경우, MongoDB 4.4.7 이상으로 다운그레이드하거나, 그렇지 않으면 이전의 비슬림형 데이터 파일을 사용하도록 시간대 데이터 파일을 되돌려야 합니다.
4. 기능 호환성 버전 다운그레이드(FCV)
먼저 다음을 확인합니다.
초기 동기화가 진행 중이 아닌지 확인합니다. 초기 동기화가 진행 중일 때
setFeatureCompatibilityVersion
명령을 실행하면 초기 동기화가 다시 시작됩니다.복제본 세트 구성 에
newlyAdded
필드가 있는 노드가 없는지 확인합니다. 복제본 세트의 각 노드에서 다음 명령을 실행하여 이를 확인합니다.use local db.system.replset.find( { "members.newlyAdded" : { $exists : true } } ); newlyAdded
필드는 초기 동기화 중과 초기 동기화 직후 노드의 복제본 세트 구성 문서에 나타납니다.2} 또는 상태의
ROLLBACK
RECOVERING
복제본 집합 구성원이 없는지 확인합니다.
다음으로 복제본 세트의 featureCompatibilityVersion
를 다운그레이드합니다.
mongo
셸을 프라이머리에 연결합니다.featureCompatibilityVersion
을"4.4"
로 다운그레이드합니다.db.adminCommand({setFeatureCompatibilityVersion: "4.4"}) setFeatureCompatibilityVersion
명령은 내부 시스템 collection에 대한 쓰기를 수행하며 멱등원입니다. 어떤 이유로든 명령이 성공적으로 완료되지 않으면 프라이머리에서 명령을 다시 시도합니다.복제본 세트의 모든 멤버가 업데이트된
featureCompatibilityVersion
을 반영하도록 하려면 각 복제본 세트 멤버에 연결하여featureCompatibilityVersion
을 확인합니다.db.adminCommand( { getParameter: 1, featureCompatibilityVersion: 1 } ) 모든 멤버는 다음을 포함하는 결과를 반환해야 합니다.
"featureCompatibilityVersion" : { "version" : "4.4" } 멤버가
"5.0"
의featureCompatibilityVersion
를 반환하는 경우 계속하기 전에 멤버가 버전"4.4"
를 반영할 때까지 기다립니다.
참고
중재자는 컬렉션 admin.system.version
을 복제하지 않습니다. 이로 인해 중재자는 복제본 세트 의 FCV 값에 관계없이 바이너리의 다운그레이드 버전과 동일한 기능 호환성 버전 을 항상 갖게 됩니다.
예를 예시 MongoDB 5.0 클러스터 의 중재자 의 FCV 값은 4.4입니다.
반환된 featureCompatibilityVersion
값에 대한 자세한 내용은 FeatureCompatibilityVersion 가져오기를 참조하세요.
5. FCV 5.0 영구 기능 제거
다음 단계는 FCV 가 "5.0"
로 설정하다 적이 있는 경우에만 필요합니다.
4.4와 호환되지 않는 영구적인 5.0 기능을 모두 제거합니다. 여기에는 다음이 포함됩니다.
- time series 컬렉션
- 모든 time series 컬렉션을 제거합니다.
런타임 감사 필터 관리
db.admin.runCommand
가 있는 그룹의 프라이머리 서버에서 기본값을 재설정합니다. 프라이머리는 업데이트할 그룹의 마지막 구성 서버여야 합니다.db.admin.runCommand( { setAuditConfig: 1, filter: {}, auditAuthorizationSuccess: false } ) 구성 문서는 다운그레이드 후에도 제거할 수 있습니다.
config.settings.remove({_id: 'audit'}); 노드의 구성 파일에서
auditLog.runtimeConfiguration
을false
로 설정하여 각 노드에서 런타임 감사 필터 관리를 비활성화합니다.로컬 구성 파일에서 이 인스턴스에 대한 감사 필터를 업데이트합니다.
6. 5.0 기능 제거
5.0 기능을 사용하는 모든 영구 기능을 제거합니다. 여기에는 다음이 포함되지만 이에 국한되지는 않습니다.
뷰 정의에
$dateAdd
또는$sampleRate
와 같은 5.0 연산자가 포함된 경우 해당 연산자를 제거해야 합니다. 전체 목록은 새 집계 연산자를 참조하세요.
절차
경고
다운그레이드 절차를 진행하기 전에 지연된 복제본 세트 멤버를 포함한 모든 복제본 세트 멤버가 필수 변경 사항을 반영하는지 확인합니다. 즉, 다운그레이드하기 전에 featureCompatibilityVersion
및 각 노드에 대해 호환되지 않는 기능 제거를 확인합니다.
복제본 세트의 세컨더리 멤버를 다운그레이드합니다.
복제본 세트의 각 세컨더리 멤버를 한 번에 하나씩 다운그레이드합니다.
mongosh
에서 다음 명령을 실행하여 완전히 종료하거나mongod
프로세스 중지 를 참조하여mongod
프로세스를 안전하게 종료합니다.db.adminCommand( { shutdown: 1 } ) 5.0 바이너리를 4.4 바이너리로 바꾸고 다시 시작합니다.
다음 세컨더리를 다운그레이드하기 전에 멤버가
SECONDARY
상태로 복구될 때까지 기다립니다. 멤버의 상태를 확인하려면 에서rs.status()
메서드를mongosh
사용합니다.멤버가
SECONDARY
단계가 되면 다음 세컨더리를 다운그레이드합니다.
중재자 복제본 세트 멤버(있는 경우)를 다운그레이드합니다.
복제본 세트에 중재자가 포함되어 있지 않으면 이 단계를 건너뛰세요.
복제본 세트의 중재자 멤버를 다운그레이드합니다.
mongosh
에서 다음 명령을 실행하여 완전히 종료하거나mongod
프로세스를 안전하게 종료하는 추가 방법을 보려면mongod
프로세스 중지를 참조합니다.db.adminCommand( { shutdown: 1 } ) 중재자 데이터 디렉토리의 내용을 삭제합니다.
storage.dbPath
구성 설정 또는--dbpath
명령줄 옵션이 중재자mongod
의 데이터 디렉토리를 지정합니다.rm -rf /path/to/mongodb/datafiles/* 5.0 바이너리를 4.4 바이너리로 바꾸고 다시 시작합니다.
멤버가
ARBITER
상태로 복구될 때까지 기다립니다. 멤버의 상태를 확인하려면mongosh
를 멤버에 연결하고rs.status()
메서드를 실행합니다.
프라이머리을 내려놓습니다.
에서 를 사용하여 프라이머리 rs.stepDown()
mongosh
를 물러나고 일반적인 페일오버 절차를 강제 실행합니다.
rs.stepDown()
rs.stepDown()
은 페일오버 절차를 신속하게 수행할 수 있으며 프라이머리를 직접 종료하는 것보다 낫습니다.
이전 프라이머리 을(를)mongod
교체하고 다시 시작합니다.
rs.status()
가 프라이머리가 물러나고 다른 멤버가 PRIMARY
상태를 취했음을 표시하는 경우:
mongosh
에서 다음 명령을 실행하여 완전히 종료하거나mongod
프로세스를 안전하게 종료하는 추가 방법을 보려면mongod
프로세스 중지를 참조합니다.db.adminCommand( { shutdown: 1 } ) mongod
바이너리를 4.4 바이너리로 바꾸고 다시 시작합니다.