Rolling forward a standby database involves applying incremental backups to synchronize changes made to the primary database. This process becomes more complicated when a new datafile is added to the primary database. In this article, I will outline the essential steps and considerations involved in rolling forward a standby database using RMAN incremental backups after the addition of a datafile on the primary side.
Step 1: Check and compare the current condition of the primary and standby databases
1.1. On the primary, identify the current sequence number of archived logs that have not been applied to the standby, which is 119311
data:image/s3,"s3://crabby-images/e6f8f/e6f8fcb3427c01621e18140f5d540e420d1bdb17" alt="rman rman"
1.2. On the standby, identify the latest sequence number of archive logs from the primary that has been applied to the standby, which is 102323″
data:image/s3,"s3://crabby-images/431f5/431f5cefede1e83d48f667edf3c2dbff90d1829c" alt="rman2 rman2"
1.3. Determine the size and current SCN of the primary and standby databases
On the primary
data:image/s3,"s3://crabby-images/7ba76/7ba76e814f87e5c0e7bac26a3b2463e75d0d122e" alt="rman3 rman3"
data:image/s3,"s3://crabby-images/0f0ee/0f0eea668c83838c6cc09006dbe971f6a75ace57" alt="rman4 rman4"
On the standby
data:image/s3,"s3://crabby-images/7f48f/7f48f1eba7784b96cbc6d12ed2a3c550eec5fb2a" alt="rman5 rman5"
data:image/s3,"s3://crabby-images/3f9f3/3f9f33676fc2e24d95868bf66c1e1e06236cc2c3" alt="rman6 rman6"
As you can see, the primary database has grown by about 10GB since it was last in sync with the standby database. Therefore, the best and fastest way to sync the primary and standby is to get incremental backup from SCN 5975444041629 on the primary, apply it on the standby, and then sync 2 databases.
1.4. On the primary, check whether datafiles have been added after the standby became out of sync
First, we need to determine the date of the current SCN on the standby database using the following query:
SELECT SCN_TO_TIMESTAMP(5975444041629) AS last_update_date FROM dual;
Then, we should check the primary to identify the datafiles that were created after this date.
data:image/s3,"s3://crabby-images/52e0f/52e0f493427352ad1e31068151fc4ad1fdd8c261" alt="rman7 rman7"
Step 2: Normally, we need to get an incremental backup from the primary database based on the minimum checkpoint_change# of the datafiles in the standby, as well as a backup of the primary control file. In addition to these two backups, we need to include a backup of the newly added datafile on the primary. Therefore, the following is what we should do:
2.1. On the standby database, find the SCN which will be used for the incremental backup at the primary database. The results of the following queries usually are the same. However, if there is a huge difference it is better to take the backup using the SCN from the second query (lesser SCN), as one of the datafiles may be behind
SQL> SELECT CURRENT_SCN FROM V$DATABASE;
SQL> select min(checkpoint_change#) from v$datafile_header;
On the standby database, stop the managed recovery process (MRP)
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;
2.2. On the primary database, back up the current control file
data:image/s3,"s3://crabby-images/43813/4381305dd96248d5acf10c40bb48cce664db017d" alt="rman8 rman8"
2.3. On the primary database, back up the database from the specific SCN
data:image/s3,"s3://crabby-images/8ee1d/8ee1df99e9832dc0da20d1cc719f6af5aa2c1e81" alt="rman9 rman9"
2.4 On the primary database, back up the added datafiles
data:image/s3,"s3://crabby-images/61f06/61f06d17a7001ab7e4c4132dadffbff2ab0ecb8e" alt="rman10 rman10"
Step 3. Copy all backup sets created on the primary system to the standby system and restore them to the standby database.
3.1. Restore the backed-up control file.
data:image/s3,"s3://crabby-images/df41c/df41c98d21220c8113623f1bf64cae905171ea66" alt="rman11 rman11"
3.2. Catalog the backups
data:image/s3,"s3://crabby-images/9a8a3/9a8a35df0807745ea481717e1fd87c65ad289e1e" alt="rman12 rman12"
3.3. Restore newly added datafiles:
data:image/s3,"s3://crabby-images/c0c09/c0c09a64703f66e60cf0114c708f134e7b59b1c8" alt="rman13 rman13"
3.4. Update the datafile names in the new standby control file. Because the control file is restored from the PRIMARY database and OMF is enabled, cataloging the datafiles in the STANDBY will automatically handle the necessary renaming operations.
You can use the following command to catalog datafiles.
RMAN> CATALOG START WITH '+DATA/<db_unique_name>/datafile/';
Since my datafiles were on the ACFS, I used the following commands to catalog datafiles.
data:image/s3,"s3://crabby-images/58c50/58c50abc26eed90c1f525b0a3c6a150dfced7986" alt="rman14 rman14"
After cataloging all the files, switch the database to the copy:
data:image/s3,"s3://crabby-images/5624f/5624fac1bdfffa185d290c88636a1cd91c3e0cfd" alt="rman15 rman15"
3.5. Recover the database using the incremental backup (the backup that we have from SCN 5975444041629)
data:image/s3,"s3://crabby-images/48af6/48af6fafa2eccfb5c90e7bd11318c35675ebf645" alt="rman16 rman16"
3.6. On the standby database, clear all standby redo log groups:
SQL> ALTER DATABASE CLEAR LOGFILE GROUP 1;
SQL> ALTER DATABASE CLEAR LOGFILE GROUP 2;
SQL> ALTER DATABASE CLEAR LOGFILE GROUP 3;
4. Now, we can verify that the databases are working correctly and are synchronized on the primary.
data:image/s3,"s3://crabby-images/14d17/14d17367f23cfefdf98151fa06d9985c4309a845" alt="rman17 rman17"
4.1. On the standby database, start the MRP and verify that log shipping is functioning correctly
data:image/s3,"s3://crabby-images/c1039/c1039d433f4bfb1b2e3bb4da4e15d00bd47be437" alt="rman18 rman18"