Overview:
For example, an archive gap
occurs when the network becomes unavailable and automatic archiving from the
primary database to the standby database stops. When the network is available
again, automatic transmission of the redo data from the primary database to the
failed standby database resumes.
Possible and common Causes for Archive Gaps are:
- Network Disconnects or stop of Log Transport Services
- Outages of the Standby Database
- Misconfigurations of Log Transport Services
- I/O-Issues on the Standby Site
- Manual Deletion of ArchiveLogs before they are applied to the Standby
- Insufficient Bandwith in the Network between the Primary and Standby Site
Methods of Gap Resolution:
Automatic Gap Resolution:
Starting
in 9.2.0, automatic gap resolution has been enhanced. In addition to the
above, the ARCH process on the primary database polls all standby databases
every minute to see if there is a gap in the sequence of archived redo logs. If
a gap is detected then the ARCH process sends the missing archived redo log
files to the standby databases that reported the gap. Once the gap is resolved,
the LGWR process is notified that the site is up to date.
FAL Gap Resolution:
FAL_SERVER: An OracleNet service
name that exist in the standby tnsnames.ora file that points to the primary
db listener. The FAL_SERVER parameter can contain a comma delimited list of
locations that should be attempted during gap resolution.
FAL_CLIENT: An OracleNet service
name that exist in the primary tnsnames.ora file that points to the standby
database listener. The value of FAL_CLIENT should also be listed as the service
in a remote archive destination pointing to the standby.
Once MRP needs to resolve a gap
it uses the value from FAL_SERVER to call the primary database. Once
communication with the primary has been established, MRP passes the FAL_CLIENT
value to the primary ARCH process. The primary ARCH process locates the remote
archive destination with the corresponding service name and ships the missing
archived redo logs. If the first destination listed in FAL_SERVER is unable to
resolve the gap then the next destination is attempted until either the gap is
resolved or all FAL_SERVER destination have been tried.
As of 9.2.0 FAL Gap Resolution
only works with Physical Standby databases as the process is tied to MRP. Gap
recovery on a logical standby database is handled through the
heartbeat mechanism.
Simulating Gap Recovery
Automatic Gap Resolution:
1. Shutdown the physical standby
database.
FAL Gap Resolution:
1. In the standby init.ora define
the fal_server and fal_client parameters.
Manually Resolving a Gap:
On your physical standby database:
SQL> SELECT * FROM
V$ARCHIVE_GAP;
THREAD# LOW_SEQUENCE#
HIGH_SEQUENCE#
The query results show that your
physical standby database is currently missing logs from sequence 443 to
sequence 446 for thread 1. After you identify the gap, issue the following
SQL statement on the primary database to locate the archived redo logs on
your primary database:
SQL> SELECT NAME FROM
V$ARCHIVED_LOG WHERE THREAD#=1 AND
DEST_ID=1 AND SEQUENCE# BETWEEN 443 AND 446;
NAME
Copy the logs returned by the
query to your physical standby database and
SQL> ALTER DATABASE
REGISTERLOGFILE '/u01/oradata/stby/arch/arch_1_443.arc';
Once the log files have been
registered in the standby controlfile, you can restart the MRP process.
On a logical standby
database:
SQL> SELECT THREAD#, SEQUENCE#, FILE_NAME FROM DBA_LOGSTDBY_LOG
L WHERE NEXT_CHANGE# NOT IN (SELECT
FIRST_CHANGE# FROM DBA_LOGSTDBY_LOG WHERE L.THREAD# = THREAD#) ORDER
BY THREAD#,SEQUENCE#;
THREAD#
SEQUENCE#
FILE_NAME
Copy
the missing logs to the logical standby system and register them using the ALTER DATABASE REGISTER LOGICAL
LOGFILE statement on your
logical standby db.
SQL>
ALTER DATABASE REGISTER LOGICAL LOGFILE
/u01/oradata/logical_stby/arch/arch_1_452.arc;
After
you register these logs on the logical standby database, you can restart log apply services.
Ref:
https://sysdbagurus.wordpress.com/2017/04/03/data-guard-gap-detection-and-resolution/
Data Guard Gap Detection and Resolution Possibilities (Doc ID 1537316.1)
0 comments:
Post a Comment