Distribuisci istanze di sincronizzazione remota di Active Data Guard

Distribuisci istanze di sincronizzazione remota su VM OCI Compute in ogni area per garantire una perdita di dati pari a zero in tutte le aree.

  1. Creare un file di controllo di Far Sync dal database primario e copiarlo negli host di Far Sync.
    SQL> alter database create far sync instance controlfile as '/home/oracle/controlfs.ctl';

    Copiare il file di controllo appena creato negli host dell'istanza di sincronizzazione remota.

    scp -p controlfs.ctl farsync-region1:/u01/app/oracle/oradata/fstor/controlfs/
    scp -p controlfs.ctl farsync-region2:/u01/app/oracle/oradata/fssyd/controlfs/
  2. Copiare il password file del database primario negli host di sincronizzazione remota utilizzando i nomi delle istanze di sincronizzazione remota.
    In questo esempio, l'istanza di sincronizzazione remota nell'area primaria (area 1) verrà denominata FSTOR. Pertanto, il nome del file password sarà orapwFSTOR.
    # check the location of the password file
    SQL> select file_name from v$passwordfile_info;
                        
    # as grid user, copy the file from ASM to the local filesystem
    asmcmd -p
    cp +DATAC2/DB_REGION1/PASSWORD/pwddb_region1.421.1185102507 /home/grid/orapw
                       
    # as root user, change the owner of the password file to oracle user
    cp /home/grid/orapw /home/oracle/
    chown oracle:oinstall /home/oracle/orapw
                        
    # copy the files to the Far Sync instance hosts using the new names "orapwFSTOR" and "orapwFSSYD"
    scp -p /home/oracle/orapw farsync-region1:/u01/app/oracle/product/19c/dbhome_1/dbs/orapwFSTOR
    scp -p /home/oracle/orapw farsync-region2:/u01/app/oracle/product/19c/dbhome_1/dbs/orapwFSSYD
  3. Creare un file di parametri per l'istanza di sincronizzazione remota dal database primario, copiarlo negli host dell'istanza di sincronizzazione remota e modificare i parametri in modo da riflettere i valori dei parametri e i percorsi di directory per l'istanza di sincronizzazione remota. In alternativa, è possibile iniziare con un nuovo file di parametri sugli host dell'istanza di sincronizzazione remota, ad esempio nell'area Primaria.
    1. Nella regione principale (FSTOR):
      # create a parameter file
      vi /u01/app/oracle/product/19c/dbhome_1/dbs/init_FSTOR.ora
      *.db_name='DBTOR'
      *.db_unique_name='FSTOR'
      *.compatible='19.0.0'
      *.control_files='/u01/app/oracle/oradata/fstor/controlfs/controlfs.ctl'
      *.diagnostic_dest='/u01/app/oracle/oradata/fstor/diag/'
      *.core_dump_dest='/u01/app/oracle/oradata/fstor/coredump/'
      *.audit_file_dest='/u01/app/oracle/oradata/fstor/audit/'
      *.audit_trail='DB'
      *.db_recovery_file_dest='/u01/app/oracle/oradata/fstor/fra/'
      *.db_recovery_file_dest_size=250g
      *.dg_broker_config_file1='/u01/app/oracle/oradata/fstor/dg_broker/fstor_01.dat'
      *.dg_broker_config_file2='/u01/app/oracle/oradata/fstor/dg_broker/fstor_02.dat'
      *.dg_broker_start=TRUE*.dispatchers='(PROTOCOL=TCP) (SERVICE=FSTORXDB)'
      *.standby_file_management='AUTO'
                                  
      # start the instance with the parameter file
      export ORACLE_SID=FSTOR
      sqlplus / as sysdba
      startup pfile='/u01/app/oracle/product/19c/dbhome_1/dbs/init_FSTOR.ora' nomount;
                                  
      # create an spfile
      create spfile='/u01/app/oracle/product/19c/dbhome_1/dbs/spfileFSTOR.ora' from pfile='/u01/app/oracle/product/19c/dbhome_1/dbs/init_FSTOR.ora';
                                  
      # restart the instance with the spfile
      shutdown immediate;
      startup mount;
      select name, db_unique_name, database_role, open_mode from v$database;
    2. Nell'area di standby (FSSYD):
      # create a parameter file
      vi /u01/app/oracle/product/19c/dbhome_1/dbs/init_FSSYD.ora
      *.db_name='DBTOR'
      *.db_unique_name='FSSYD'
      *.compatible='19.0.0'
      *.control_files='/u01/app/oracle/oradata/fssyd/controlfs/controlfs.ctl'
      *.diagnostic_dest='/u01/app/oracle/oradata/fssyd/diag/'
      *.core_dump_dest='/u01/app/oracle/oradata/fssyd/coredump/'
      *.audit_file_dest='/u01/app/oracle/oradata/fssyd/audit/'
      *.audit_trail='DB'
      *.db_recovery_file_dest='/u01/app/oracle/oradata/fssyd/fra/'
      *.db_recovery_file_dest_size=250g
      *.dg_broker_config_file1='/u01/app/oracle/oradata/fssyd/dg_broker/fssyd_01.dat'
      *.dg_broker_config_file2='/u01/app/oracle/oradata/fssyd/dg_broker/fssyd_02.dat'
      *.dg_broker_start=TRUE
      *.dispatchers='(PROTOCOL=TCP) (SERVICE=FSSYDXDB)'
      *.standby_file_management='AUTO'
                                  
      # start the instance with the parameter file
      export ORACLE_SID=FSSYD
      sqlplus / as sysdba
      startup pfile='/u01/app/oracle/product/19c/dbhome_1/dbs/init_FSSYD.ora' nomount;
                                  
      # create an spfile
      create spfile='/u01/app/oracle/product/19c/dbhome_1/dbs/spfileFSSYD.ora' from pfile='/u01/app/oracle/product/19c/dbhome_1/dbs/init_FSSYD.ora';
                                  
      # restart the instance with the spfile
      shutdown immediate;
      startup mount;
      select name, db_unique_name, database_role, open_mode from v$database;
  4. Creare e avviare un listener di database su ogni host di sincronizzazione remota.
    1. Nella regione principale:
      vi $ORACLE_HOME/network/admin/listener.ora
      LISTENER =
        (DESCRIPTION_LIST =
          (DESCRIPTION =
            (ADDRESS = (PROTOCOL = TCP)(HOST = farsync-region1.hubsubnetregion1.hubvcnregion1.oraclevcn.com)(PORT = 1521))
            (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
          )
        )
                                  
      lsnrctl start
      lsnrctl services
    2. Nell'area Standby:
      vi $ORACLE_HOME/network/admin/listener.ora
      LISTENER =
        (DESCRIPTION_LIST =
          (DESCRIPTION =
            (ADDRESS = (PROTOCOL = TCP)(HOST = farsync-region2.hubsubnetregion2.hubvcnregion2.oraclevcn.com)(PORT = 1521))
            (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
          )
        )
                                  
      lsnrctl start
      lsnrctl services
  5. Aggiungere voci TNS primarie e in standby negli host Far Sync.
    vi $ORACLE_HOME/network/admin/tnsnames.ora
                        
    DB_REGION1 =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = vmc1ca-4vzoi-scan.ocidbdelegated.ocivnoffsitedb.oraclevcn.com)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = db_region1.ocidbdelegated.ocivnoffsitedb.oraclevcn.com)
        )
      )
    
    DB_REGION2 =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = abvmc1auseh-glcfo-scan.ociabvnet5subn.ociabvirtualne.oraclevcn.com)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = db_region2.ociabvnet5subn.ociabvirtualne.oraclevcn.com)
        )
      )
  6. Aggiungere le voci TNS di sincronizzazione remota negli host del database primario e in standby e verificare la connettività.

    Aggiungere le stringhe di connessione TNS delle istanze di sincronizzazione remota al file tnsname.ora negli host del database primario e in standby (su tutti gli host del cluster VM Exadata).

    vi $ORACLE_HOME/network/admin/dbtor/tnsnames.ora
    FSTOR =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = farsync-region1)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = FSTOR)
        )
      )
    
    FSSYD =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = farsync-region2)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = FSSYD)
        )
      )
    # Test the connectivity
    sqlplus SYS@FSTOR as sysdba
    show parameter instance_name
    
    sqlplus SYS@FSSYD as sysdba
    show parameter instance_name
    
    # If the connection fails, ensure port 1521 is open on Far Sync hosts
    sudo firewall-cmd --permanent --add-port=1521/tcp
    sudo firewall-cmd --reload
  7. Aggiungere e abilitare le istanze di sincronizzazione remota nella configurazione del broker Active Data Guard (dal database primario).

    Utilizzare il broker Active Data Guard per aggiungere l'istanza di sincronizzazione remota alla configurazione Active Data Guard esistente durante la connessione al database primario.

    dgmgrl SYS as sysdba
    
    DGMGRL> ADD FAR_SYNC FSTOR AS CONNECT IDENTIFIER IS FSTOR;
    DGMGRL> ENABLE FAR_SYNC FSTOR;
    
    DGMGRL> ADD FAR_SYNC FSSYD AS CONNECT IDENTIFIER IS FSSYD;
    DGMGRL> ENABLE FAR_SYNC FSSYD;
  8. Configurare le proprietà RedoRoutes nel broker per i database primari e le istanze di sincronizzazione remota.

    Utilizzare la proprietà RedoRoutes del broker Active Data Guard per configurare il database primario per il trasporto di redo nell'istanza di sincronizzazione remota locale in modalità FastSync e nell'istanza di sincronizzazione remota per inoltrare redo al database di standby remoto in modalità ASYNC.

    DGMGRL> EDIT DATABASE 'db_region1' SET PROPERTY RedoRoutes = '( LOCAL : ( FSTOR FASTSYNC PRIORITY=1, db_region2 ASYNC PRIORITY=2 ))';
    DGMGRL> EDIT FAR_SYNC 'FSTOR' SET PROPERTY RedoRoutes = '( db_region1 : db_region2 ASYNC )';
    
    DGMGRL> EDIT DATABASE 'db_region2' SET PROPERTY RedoRoutes = '( LOCAL : ( FSSYD FASTSYNC PRIORITY=1, db_region1 ASYNC PRIORITY=2 ))';
    DGMGRL> EDIT FAR_SYNC 'FSSYD' SET PROPERTY RedoRoutes = '( db_region2 : db_region1 ASYNC )';
    I parametri log_archive_dest_n del database per le istanze primarie, di standby e di sincronizzazione remota vengono impostati di conseguenza.
  9. Modificare la modalità di protezione della configurazione in Maximum Availability.
    DGMGRL> EDIT CONFIGURATION SET PROTECTION MODE AS MAXAVAILABILITY;
  10. Controllare la configurazione di Active Data Guard.
    DGMGRL> SHOW CONFIGURATION
    
    Configuration - dbtor_dgconf
    
    Protection Mode: MaxAvailability
    Members:
      db_region1 - Primary database
      fstor      - Far sync instance
      db_region2  - Physical standby database
    
    Members Not Receiving Redo:
      fssyd      - Far sync instance
    
    Fast-Start Failover:  Disabled
    
    Configuration Status:
      SUCCESS   (status updated 57 seconds ago)

    Nota

    Inizialmente, l'istanza remota di Far Sync potrebbe visualizzare Warning: ORA-16789: standby redo logs configured incorrectly finché non riceve i dati redo per la prima volta. Ad esempio, dopo uno switch ruolo o aggiornando temporaneamente gli instradamenti redo.

    Controllare la configurazione dopo lo switchover.

    DGMGRL> SHOW CONFIGURATION
    
    Configuration - dbtor_dgconf
    
    Protection Mode: MaxAvailability
    Members:
      db_region2  - Primary database
      fssyd      - Far sync instance
      db_region1 - Physical standby database
    
    Members Not Receiving Redo:
      fstor      - Far sync instance
    
    Fast-Start Failover:  Disabled
    
    Configuration Status:
      SUCCESS   (status updated 54 seconds ago)