문서 메뉴

문서 홈애플리케이션 개발MongoDB 매뉴얼

복제 세트 배포

이 페이지의 내용

  • 개요
  • 요구 사항:
  • 복제본 세트 배포 시 고려 사항
  • MongoDB Atlas UI에서 복제본 세트 배포
  • 터미널에서 복제본 세트 배포

멤버가 세 명인 복제본 세트는 대부분의 네트워크 파티션 및 기타 시스템 장애를 견딜 수 있는 충분한 중복성을 제공합니다. 이러한 세트는 많은 분산된 읽기 작업을 위한 충분한 용량을 제공하기도 합니다. 복제본 세트에는 항상 홀수의 멤버가 있어야 합니다. 이를 통해 투표를 순조롭게 진행할 수 있습니다. 복제본 세트 설계에 관한 더 자세한 내용은 복제 개요에서 확인하세요.

MongoDB Atlas에서 호스팅되는 배포서버를 위한 복제본 세트를 배포할 수 있습니다.

MongoDB Atlas에서 호스팅되는 배포서버를 위한 복제본 세트의 배포에 관해 자세히 알아보려면 MongoDB Atlas UI에서 복제본 세트 배포를 확인하세요.

프로덕션 배포의 경우 mongod 인스턴스를 별도의 머신에서 호스팅하여 멤버 간에 최대한 거리를 두어야 합니다. 프로덕션 배포에 가상 머신을 사용하는 경우, 각 mongod 인스턴스는 중복 전원 회로 및 중복 네트워크 경로를 통해 서비스되는 별도의 호스트 서버에 배치해야 합니다.

복제본 세트를 배포하려면 먼저 복제본 세트의 일부가 될 각 시스템에 MongoDB를 설치해야 합니다. MongoDB를 아직 설치하지 않은 경우 설치 튜토리얼을 참조하세요.

프로덕션 환경에서는 복제본 세트의 각 멤버를 자체 머신에 배포합니다. 가능하다면 MongoDB가 기본 포트 27017에서 수신 대기하는지 확인합니다.

참고

롤링 업그레이드 외에는 복제본 세트 mongod 의 모든 멤버는 동일한 주요 버전의 MongoDB를 사용해야 합니다.

자세한 내용은 복제 세트 배포 아키텍처를참조하세요.

중요

변경된 IP 주소로 인해 구성이 업데이트되는 것을 방지하려면 IP 주소 대신 DNS 호스트 이름을 사용하세요. 특히 복제본 세트 구성원 또는 샤드 클러스터 구성원을 구성할 때 IP 주소 대신 DNS 호스트 이름을 사용하는 것이 중요합니다.

IP 주소 대신 호스트 이름을 사용하여 분할된 네트워크 범위에 걸쳐 클러스터를 구성합니다. MongoDB 5 부터 시작.0, IP 주소로만 구성된 노드는 시작 유효성 검사에 실패하여 시작되지 않습니다.

--bind_ip 2} 옵션을 사용하여 MongoDB가 구성된 주소의 애플리케이션에서 연결을 수신 대기하도록 합니다.

버전 3.6에서 변경:

경고

공개적으로 액세스할 수 있는 IP 주소에 인스턴스를 바인딩하기 전에 무단 액세스로부터 클러스터를 보호해야 합니다. 보안 권장 사항의 전체 목록은 보안 검사 목록을 참조하세요. 최소한으로 인증을 활성화하고 네트워크 인프라를 강화하는 것을 고려하세요.
MongoDB 바이너리 mongodmongos 는 기본적으로 로컬 호스트에 바인딩됩니다. 바이너리에 대해 net.ipv6 구성 파일 설정 또는 --ipv6 명령줄 옵션이 설정된 경우 바이너리는 로컬 호스트 IPv6 주소에 추가로 바인딩됩니다. 기본적으로 로컬 호스트에만 바인딩되는 mongodmongos 동일한 컴퓨터에서 실행 중인 클라이언트의 연결을 수락합니다. 이 바인딩 동작에는 mongosh 및 복제본 세트 또는 샤드 클러스터의 다른 멤버가 포함됩니다. 원격 클라이언트는 로컬 호스트에만 바인딩된 바이너리에는 연결할 수 없습니다. 기본 바인딩을 재정의하고 다른 IP 주소에 바인딩하려면 net.bindIp 구성 파일 설정 또는 --bind_ip 명령줄 옵션을 사용하여 호스트 이름 또는 IP 목록을 지정합니다. 주소.

경고

MongDB 부터 5 시작됩니다.0, 분할 수평 DNS IP 주소로만 구성된 노드는 시작 유효성 검사에 실패하고 오류를 보고합니다. 를 참조하세요.disableSplitHorizonIPCheck
예를 들어, 다음 mongod 인스턴스는 로컬 호스트와 IP 주소 198.51.100.1 연결된 호스트 이름 My-Example-Associated-Hostname 모두에 바인딩됩니다.
mongod --bind_ip localhost,My-Example-Associated-Hostname
이 인스턴스에 연결하려면 원격 클라이언트가 호스트 이름 또는 관련 IP 주소 198.51.100.1를 지정해야 합니다.
mongosh --host My-Example-Associated-Hostname
mongosh --host 198.51.100.1

네트워크 트래픽이 세트의 모든 구성원과 네트워크의 모든 클라이언트 간에 안전하게 전달될 수 있는지 확인하십시오.

다음 사항을 고려하세요:

  • 가상 사설망을 설정합니다. 네트워크 토폴로지가 LAN을 통해 단일 사이트 내의 구성원 간 모든 트래픽을 라우팅하는지 확인하십시오.

  • 알 수 없는 클라이언트에서 복제본 세트로의 연결을 방지하도록 액세스 제어를 구성합니다.

  • 수신 및 발신 패킷이 기본 MongoDB 포트에서만 허용되고 배포 내에서만 허용되도록 네트워킹 및 방화벽 규칙을 구성합니다. IP 바인딩 고려 사항을 참조하세요.

복제본 세트의 각 구성원이 확인 가능한 DNS 또는 호스트 이름을 통해 액세스할 수 있는지 확인합니다. DNS 이름을 적절하게 구성하거나 시스템의 /etc/hosts 파일을 설정하여 이 구성을 반영해야 합니다.

각 멤버는 다른 모든 멤버와 연결할 수 있어야 합니다. 연결을 확인하는 방법에 대한 지침은 모든 구성원 간의 연결 테스트를 참조하십시오.

MongoDB를 배포하기 전에 MongoDB가 데이터 파일을 저장하는 디렉터리를 만드세요.

5} 또는 관련 위치에 mongod 저장된 구성 파일에서 구성을 지정합니다./etc/mongod.conf

구성 옵션에 대한 자세한 내용은 구성 파일 옵션을 참조하십시오.

MongoDB Atlas의 복제본 세트를 클러스터라고 합니다. 다음 절차에서는 최소한의 구성으로 MongoDB Atlas UI에서 무료 클러스터를 생성합니다. 클러스터를 생성할 때 사용할 수 있는 모든 옵션에 대해 자세히 알아보려면 클러스터 생성을 참조하세요.

MongoDB Atlas UI에서 클러스터를 생성하려면 다음 단계를 따르세요.

1
  1. MongoDB Atlas UI의 Database 사이드바에서 버튼을 클릭합니다.

  2. 이미 하나 이상의 데이터베이스 배포서버가 있는 경우 Create를 클릭합니다. 첫 번째 데이터베이스 배포서버인 경우, Build a Database를 클릭한 다음 Advanced Configuration Options을 클릭합니다.

2
  1. Shared를 클릭합니다.

  2. 클라우드 제공자 및 리전을 선택합니다. 자세한 내용은 클라우드 제공자 및 리전을 참조하세요.

  3. Cluster Details 섹션을 확장하고 Cluster Name 필드에 클러스터의 이름을 지정합니다.

3

MongoDB Atlas는 사용자가 지정한 클러스터 이름으로 노드가 3개인 무료 복제본 세트를 배포합니다.

이 튜토리얼에서는 액세스 제어를 비활성화한 상태로 실행 중인 3개의 기존 mongod 인스턴스에서 3명의 멤버로 구성된 복제본 세트를 생성하는 방법을 설명합니다.

액세스 제어가 활성화된 복제본 세트를 배포하려면 키 파일 인증을 사용하여 복제본 세트 배포를 참조하세요. 단일 MongoDB 인스턴스에서 복제본 세트를 배포하려면 독립형 mongod를 복제본 세트로 변환을 참조하세요. 복제본 세트 배포서버에 관한 자세한 내용은 복제복제본 세트 배포서버 아키텍처 문서에서 확인하세요.

1

각 멤버에 대해 다음 설정을 사용하여 mongod 인스턴스를 시작합니다.

  • 복제본 세트 이름에 replication.replSetName 옵션을 설정합니다. 애플리케이션이 2개 이상의 복제본 세트에 연결된 경우 각 세트의 이름이 달라야 합니다.

  • net.bindIp 2} 옵션을 호스트 이름/IP 또는 쉼표로 구분된 호스트 이름/IP 목록으로 설정합니다.

  • 다른 설정은 배포에 맞게 적절하게 설정합니다.

이 자습서에서는 세 개의 mongod 인스턴스가 다음 호스트와 연결됩니다.

복제본 세트 멤버
호스트 이름
회원 0
mongodb0.example.net
회원 1
mongodb1.example.net
멤버 2
mongodb2.example.net

다음 예에서는 --replSet--bind_ip 명령줄 옵션을 통해 복제본 세트 이름과 IP 바인딩을 지정합니다.

경고

공개적으로 액세스할 수 있는 IP 주소에 인스턴스를 바인딩하기 전에 무단 액세스로부터 클러스터를 보호해야 합니다. 보안 권장 사항의 전체 목록은 보안 검사 목록을 참조하세요. 최소한으로 인증을 활성화하고 네트워크 인프라를 강화하는 것을 고려하세요.

mongod --replSet "rs0" --bind_ip localhost,<hostname(s)|ip address(es)>

0}의 <hostname(s)|ip address(es)> 경우 원격 클라이언트(복제본 집합의 다른 구성원 포함)가 인스턴스에 연결하는 데 사용할 수 있는 인스턴스의 호스트 mongod 이름 및/또는 IP 주소를 지정합니다.

또는 구성 파일에서 replica set name ip addresses와 를 지정할 수도 있습니다.

replication:
replSetName: "rs0"
net:
bindIp: localhost,<hostname(s)|ip address(es)>

구성 파일로 mongod 시작하려면 --config 옵션으로 구성 파일의 경로를 지정합니다.

mongod --config <path-to-config>

프로덕션 배포에서는 이 프로세스를 관리하도록 초기화 스크립트를 구성할 수 있습니다. 초기화 스크립트는 이 문서의 범위를 벗어납니다.

2

mongod 중 하나가 실행 중인 동일한 머신(이 튜토리얼에서는 mongodb0.example.net)에서 mongosh 을(를) 시작합니다. 기본 포트 27017 에서 로컬 호스트를 수신 대기 중인 mongod 에 연결하려면 다음을 실행하기만 하면 됩니다.

mongosh

경로에 따라 mongosh 바이너리의 경로를 지정해야 할 수도 있습니다.

mongod 가 기본 포트에서 실행되고 있지 않은 경우 mongosh 에 대해 --port 옵션을 지정합니다.

3

mongosh 에서 복제본 세트 멤버 0 에서 rs.initiate() 를 실행합니다.

중요

복제본 세트에 대해 mongod rs.initiate() 하나의 인스턴스에서만 를 실행합니다.

중요

변경된 IP 주소로 인해 구성이 업데이트되는 것을 방지하려면 IP 주소 대신 DNS 호스트 이름을 사용하세요. 특히 복제본 세트 구성원 또는 샤드 클러스터 구성원을 구성할 때 IP 주소 대신 DNS 호스트 이름을 사용하는 것이 중요합니다.

IP 주소 대신 호스트 이름을 사용하여 분할된 네트워크 범위에 걸쳐 클러스터를 구성합니다. MongoDB 5 부터 시작.0, IP 주소로만 구성된 노드는 시작 유효성 검사에 실패하여 시작되지 않습니다.

rs.initiate( {
_id : "rs0",
members: [
{ _id: 0, host: "mongodb0.example.net:27017" },
{ _id: 1, host: "mongodb1.example.net:27017" },
{ _id: 2, host: "mongodb2.example.net:27017" }
]
})

MongoDB는 기본 복제본 세트 구성을 사용하여 복제본 세트를 시작합니다.

4

rs.conf() 2}를 사용하여 복제본 세트 구성 개체를 표시합니다.

rs.conf()

복제본 세트 구성 개체는 다음과 유사합니다.

{
"_id" : "rs0",
"version" : 1,
"protocolVersion" : NumberLong(1),
"members" : [
{
"_id" : 0,
"host" : "mongodb0.example.net:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : {
},
"secondaryDelaySecs" : NumberLong(0),
"votes" : 1
},
{
"_id" : 1,
"host" : "mongodb1.example.net:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : {
},
"secondaryDelaySecs" : NumberLong(0),
"votes" : 1
},
{
"_id" : 2,
"host" : "mongodb2.example.net:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : {
},
"secondaryDelaySecs" : NumberLong(0),
"votes" : 1
}
],
"settings" : {
"chainingAllowed" : true,
"heartbeatIntervalMillis" : 2000,
"heartbeatTimeoutSecs" : 10,
"electionTimeoutMillis" : 10000,
"catchUpTimeoutMillis" : -1,
"getLastErrorModes" : {
},
"getLastErrorDefaults" : {
"w" : 1,
"wtimeout" : 0
},
"replicaSetId" : ObjectId("585ab9df685f726db2c6a840")
}
}
5

rs.status() 사용하여 복제본 세트에서 주 복제본을 식별합니다.

다음도 참조하세요.

← 복제본 세트 배포 튜토리얼