Criar uma réplica somente leitura

Selecione uma versão da documentação:

Para aumentar a capacidade de processamento de leitura e a disponibilidade, crie um servidor de réplica do AlloyDB Omni para um servidor do AlloyDB Omni. Um servidor de réplica fornece um clone somente leitura do seu servidor de banco de dados primário. Ele atualiza continuamente os próprios dados para refletir alterações nos dados do servidor primário.

Nas seções a seguir, mostramos as etapas para configurar o servidor primário do AlloyDB Omni para replicação, configurar o servidor de réplica e verificar o status da replicação no servidor primário.

Antes de começar

Antes de continuar, instale e configure o AlloyDB Omni usando o pacote RPM. Para mais informações, consulte Instalar o AlloyDB Omni usando o RPM.

Configurar o servidor primário para replicação

  1. Atualize as configurações de rede ou firewall do host do servidor primário para permitir o tráfego de entrada do host do servidor de réplica pela porta Postgres do servidor primário.

  2. Crie um usuário de réplica:

    psql -h localhost -U postgres -c "create user REPLICA_USER with replication password 'PASSWORD';
    grant pg_read_all_settings to REPLICA_USER;"
  3. Adicione as seguintes linhas no arquivo /DATA_DIR/pg_hba.conf do servidor primário antes host all all all scram-sha-256 que existe no arquivo:

    host alloydbmetadata    alloydbmetadata   IP_RANGE trust
    host replication        REPLICA_USER    IP_RANGE scram-sha-256
    

    Substitua:

    • IP_RANGE: o intervalo de IP, na notação CIDR, da sub-rede em que a máquina de réplica está localizada. Por exemplo, 203.0.113.0/24.
    • DATA_DIR: o caminho do diretório de dados do servidor primário.
  4. Reinicie o servidor primário:

    sudo systemctl restart alloydbomniPG_VERSION

Criar e configurar o servidor de réplica

Para criar e configurar um servidor de réplica do AlloyDB Omni, siga estas etapas:

  1. Verifique se a réplica tem conectividade de rede com o servidor primário:

    ping SOURCE_IP

    Substitua SOURCE_IP pelo endereço IP da instância primária do AlloyDB Omni da qual será feita a replicação.

  2. Verifique se a réplica pode se conectar ao servidor primário:

    psql "host=SOURCE_IP user=REPLICA_USER replication=1" -c "IDENTIFY_SYSTEM;"

    A saída será parecida com esta:

           systemid       | timeline |  xlogpos  | dbname
     ---------------------+----------+-----------+--------
      7376500460465963036 |        1 | 0/454B670 |
      (1 row)
    
  3. A réplica precisa ter um local de armazenamento permanente no disco:

    pg_basebackup \
      --pgdata=DATA_DIR \
      --checkpoint=fast \
      --host="SOURCE_IP" \
      --port="SOURCE_PORT" \
      --username=REPLICA_USER \
      --create-slot \
      --write-recovery-conf \
      --slot="SLOT_NAME"

    Substitua:

    • SOURCE_PORT: a porta TCP da instância primária do AlloyDB Omni da qual será feita a replicação. Se você não fornecer esse valor, o AlloyDB Omni vai aplicar o valor padrão 5432.
    • SLOT_NAME: o rótulo do nome do slot de replicação.
    • DATA_DIR: o caminho do diretório de dados do servidor de réplica.
  4. Inicie a instância de réplica:

    sudo systemctl start alloydbomniPG_VERSION

Verificar o status da replicação no servidor primário

Para verificar se a replicação está configurada corretamente, execute o seguinte comando no host do servidor primário:

psql -h localhost -U postgres -c "select * from pg_stat_replication"

A tabela de resposta contém uma linha para cada réplica conectada ao servidor de banco de dados primário.

Depois que você configura a replicação, todas as inserções, atualizações e exclusões de linhas no servidor de banco de dados primário ficam legíveis na réplica em poucos segundos.