Active Data Guard-Far-Sync-Instanzen bereitstellen
Stellen Sie Far Sync-Instanzen auf OCI Compute-VMs in jeder Region bereit, um regionsübergreifend keinen Datenverlust zu gewährleisten.
- Erstellen Sie eine Far Sync-Kontrolldatei aus der Primärdatenbank, und kopieren Sie sie auf die Far Sync-Hosts.
SQL> alter database create far sync instance controlfile as '/home/oracle/controlfs.ctl';
Kopieren Sie die neu erstellte Kontrolldatei in die Far Sync-Instanzhosts.
scp -p controlfs.ctl farsync-region1:/u01/app/oracle/oradata/fstor/controlfs/ scp -p controlfs.ctl farsync-region2:/u01/app/oracle/oradata/fssyd/controlfs/
- Kopieren Sie die Kennwortdatei der Primärdatenbank mit den Far Sync-Instanznamen in die Far Sync-Hosts.In diesem Beispiel erhält die Far Sync-Instanz in der primären Region (Region 1) den Namen
FSTOR
. Daher lautet der Name der KennwortdateiorapwFSTOR
.# 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
- Erstellen Sie eine Parameterdatei für die Far Sync-Instanz aus der Primärdatenbank, kopieren Sie sie in die Far Sync-Instanzhosts, und passen Sie die Parameter so an, dass sie Ihre Parameterwerte und Verzeichnispfade für die Far Sync-Instanz widerspiegeln. Alternativ können Sie mit einer neuen Parameterdatei auf den Far Sync-Instanzhosts beginnen (z.B. im Bereich "Primär").
- In der primären Region (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;
- In der Standbyregion (
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;
- In der primären Region (FSTOR):
- Erstellen und starten Sie einen Datenbank-Listener auf jedem Far Sync-Host.
- In der primären Region:
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
- In der Standby-Region:
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
- In der primären Region:
- Fügen Sie primäre und Standby-TNS-Einträge auf den Far Sync-Hosts hinzu.
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) ) )
- Fügen Sie die Far Sync TNS-Einträge auf den Hosts der Primär- und Standbydatenbank hinzu, und testen Sie die Konnektivität.
Fügen Sie die TNS-Verbindungszeichenfolgen der Far Sync-Instanzen zur Datei
tnsname.ora
auf den Hosts der Primär- und Standbydatenbank (auf allen Hosts des Exadata-VM-Clusters) hinzu.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
- Fügen Sie die Far Sync-Instanzen in der Brokerkonfiguration Active Data Guard (aus der Primärdatenbank) hinzu, und aktivieren Sie sie.
Verwenden Sie den Active Data Guard-Broker, um die Far Sync-Instanz der vorhandenen Active Data Guard-Konfiguration hinzuzufügen, während Sie mit der Primärdatenbank verbunden sind.
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;
- Konfigurieren Sie
RedoRoutes
-Eigenschaften im Broker für Primärdatenbanken und Far Sync-Instanzen.Verwenden Sie die Eigenschaft
RedoRoutes
des Active Data Guard-Brokers, um die Primärdatenbank so zu konfigurieren, dassredo
imFastSync
-Modus an die lokale Far Sync-Instanz übertragen wird, und die Far Sync-Instanz, umredo
imASYNC
-Modus an die Remote-Standbydatenbank weiterzuleiten.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 )';
Dielog_archive_dest_n
-Parameter der Datenbank für die Primär-, Standby- und Far Sync-Instanzen werden entsprechend festgelegt. - Ändern Sie den Konfigurationsschutzmodus in
Maximum Availability
.DGMGRL> EDIT CONFIGURATION SET PROTECTION MODE AS MAXAVAILABILITY;
- Prüfen Sie die Active Data Guard-Konfiguration.
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)
Hinweis:
Anfänglich kann die Remote Far Sync-InstanzWarning: ORA-16789: standby redo logs configured incorrectly
anzeigen, bis sie zum ersten Malredo
-Daten empfängt. Beispiel: nach einem Rollenwechsel oder durch temporäre Aktualisierung vonredo
-Routen.Prüfen Sie die Konfiguration nach dem 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)