Gestione del failover di un database PostgreSQL

Edge per il cloud privato v4.18.01

Durante un failover del database PostgreSQL, esegui le seguenti operazioni:

  1. Arresta Apigee-postgresql sul master attuale se è ancora in esecuzione:
    > /opt/apigee/apigee-service/bin/apigee-service apigee-postgresql stop
  2. Vai al nodo standby e richiama il comando seguente per impostarlo come master:
    > /opt/apigee/apigee-service/bin/apigee-service Apigee.post-regresql promuovi-standby-to-master IPorDNSofOldMaster

Se in futuro verrà ripristinato il master precedente, impostalo come nodo in standby:

  1. Sul master attuale, modifica il file di configurazione per impostare:
    PG_MASTER=IPorDNSofNewMaster
    PG_STANDBY=IPorDNSofOldMaster
  2. Abilita la replica sul nuovo master:
    > /opt/Apigee/apigee-service/bin/apigee-service apigee-postgresql setup-replication-on-master -f configFIle
  3. Sul vecchio master, modifica il file di configurazione per impostare:
    PG_MASTER=IPorDNSofNewMaster
    PG_STANDBY=IPorDNSofOldMaster
  4. Arresta apigee-postgresql sul vecchio master:
    > /opt/apigee/apigee-service/bin/apigee-service Apigee.postgresql
  5. Nel master precedente, elimina i dati Postgres precedenti:
    > rm -rf /opt/apigee/data/apigee-postgresql/

    Nota: se necessario, puoi eseguire il backup di questi dati prima di eliminarli.
  6. Configura il vecchio master come standby:
    > /opt/apigee/apigee-service/bin/apigee-service Apigee-postgresql setup-replication-on-standby -f configFile
  7. Al termine della replica, verifica lo stato della replica inviando i seguenti script su entrambi i server. Il sistema dovrebbe mostrare risultati identici su entrambi i server per garantire una replica riuscita:
    1. Sul nodo master, esegui:
      > /opt/apigee/apigee-service/bin/apigee-service-apigee-postgresql postgres-check-master

      Verifica che sia il master.
    2. Sul nodo standby:
      > /opt/apigee/apigee-service/bin/apigee-service-apigee-postgresql postgres-check-standby

      Verifica che sia in standby.