다음 섹션에서는 복제용 AlloyDB Omni 기본 서버와 복제본 서버를 구성하고 기본 서버에서 복제 상태를 확인하는 단계를 설명합니다.
시작하기 전에
계속하기 전에 RPM 패키지를 사용하여 AlloyDB Omni를 설치하고 설정합니다. 자세한 내용은 RPM을 사용하여 AlloyDB Omni 설치를 참조하세요.
복제용 기본 서버 구성
기본 서버의 Postgres 포트를 통해 복제본 서버의 호스트에서 인그레스 트래픽을 허용하도록 기본 서버 호스트의 네트워크 또는 방화벽 설정을 업데이트합니다.
복제 사용자를 만듭니다.
psql -h localhost -U postgres -c "create user REPLICA_USER with replication password 'PASSWORD'; grant pg_read_all_settings to REPLICA_USER;"파일에 있는
host all all all scram-sha-256that exists **앞에** 기본 서버의/DATA_DIR/pg_hba.conffile of 파일에 다음 줄을 추가합니다.host alloydbmetadata alloydbmetadata IP_RANGE trust host replication REPLICA_USER IP_RANGE scram-sha-256다음을 바꿉니다.
IP_RANGE: 표시된 복제본 머신이 있는 CIDR 표기법으로 서브넷의 IP 범위. 예를 들면203.0.113.0/24입니다.DATA_DIR: 기본 서버의 데이터 디렉터리 경로
기본 서버를 다시 시작합니다.
sudo systemctl restart alloydbomniPG_VERSION
복제본 서버 만들기 및 구성
AlloyDB Omni 복제본 서버를 만들고 구성하려면 다음 단계를 완료합니다.
복제본이 기본 서버에 네트워크로 연결되어 있는지 확인합니다.
ping SOURCE_IPSOURCE_IP를 복제할 기본 AlloyDB Omni 인스턴스의 IP 주소로 바꿉니다.복제본이 기본 서버에 연결할 수 있는지 확인합니다.
psql "host=SOURCE_IP user=REPLICA_USER replication=1" -c "IDENTIFY_SYSTEM;"출력은 다음과 비슷하게 표시됩니다.
systemid | timeline | xlogpos | dbname ---------------------+----------+-----------+-------- 7376500460465963036 | 1 | 0/454B670 | (1 row)복제본은 디스크의 영구 스토리지 위치를 사용해야 합니다.
pg_basebackup \ --pgdata=DATA_DIR \ --checkpoint=fast \ --host="SOURCE_IP" \ --port="SOURCE_PORT" \ --username=REPLICA_USER \ --create-slot \ --write-recovery-conf \ --slot="SLOT_NAME"다음을 바꿉니다.
SOURCE_PORT: 복제할 기본 AlloyDB Omni 인스턴스의 TCP 포트. 이 값을 제공하지 않으면 AlloyDB Omni에서 기본값5432를 적용합니다.SLOT_NAME: 복제 슬롯 이름의 라벨DATA_DIR: 복제본 서버의 데이터 디렉터리 경로
복제본 인스턴스를 시작합니다.
sudo systemctl start alloydbomniPG_VERSION
기본 서버에서 복제 상태 확인
복제가 올바르게 구성되었는지 확인하려면 기본 서버의 호스트에서 다음 명령어를 실행합니다.
psql -h localhost -U postgres -c "select * from pg_stat_replication"출력 테이블에는 기본 데이터베이스 서버에 연결된 모든 복제본에 대해 행이 하나씩 포함됩니다.
복제를 설정하면 기본 데이터베이스 서버에서 수행된 모든 행 삽입, 업데이트, 삭제 작업을 복제본에서도 몇 초 안에 조회할 수 있습니다.