Oracle Database 12c
New Feature:
RESTORE AND RECOVER
STANDBY DATABASE
FROM NETWORK SERVICE
It is always possible to loose archivelogs in
our Prmiary-Standby Database configurations. When we loose even only one
archivelog file, a gap would occur and the automatic recovery of our standby
database stops.
We'd have several methods to resolve the gaps:
·
Restore the
archivelogs from backup and apply them manually
·
Create
incremental backup from primary and recover standby.
With the release of 12c, we have a new method
to resolve the gaps;
--->Restore&Recover from Network
Service
Steps:
1. Check the status:
SQL> SELECT distinct PROCESS, STATUS, THREAD#, SEQUENCE# FROM
V$MANAGED_STANDBY order by process;
PROCESS STATUS THREAD#
SEQUENCE#
--------- ------------ ---------- ----------
ARCH CLOSING
1 82
ARCH CLOSING
1 89
ARCH CONNECTED
0 0
MRP0 WAIT_FOR_GAP
1 86
RFS IDLE
0 0
RFS IDLE
1 90
6 rows selected.
SQL>
2. Stop the
recovery on standby
SQL> alter database recover managed standby database cancel;
Database altered.
SQL>
3. Recover the database over the network;
RMAN> recover database from service TWELVE;
Starting recover at 25-APR-16
using target database control file instead of
recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=249 device type=DISK
channel ORA_DISK_1: starting incremental
datafile backup set restore
channel ORA_DISK_1: using network backup set
from service TWELVE
destination for restore of datafile 00001:
/u01/app/oracle/oradata/TWELVE/system01.dbf
channel ORA_DISK_1: restore complete, elapsed
time: 00:00:01
channel ORA_DISK_1: starting incremental
datafile backup set restore
channel ORA_DISK_1: using network bac
kup set from service TWELVE
destination for restore of datafile 00003:
/u01/app/oracle/oradata/TWELVE/sysaux01.dbf
channel ORA_DISK_1: restore complete, elapsed
time: 00:00:03
channel ORA_DISK_1: starting incremental
datafile backup set restore
channel ORA_DISK_1: using network backup set
from service TWELVE
destination for restore of datafile 00004:
/u01/app/oracle/oradata/TWELVE/undotbs01.dbf
channel ORA_DISK_1: restore complete, elapsed
time: 00:00:02
channel ORA_DISK_1: starting incremental
datafile backup set restore
channel ORA_DISK_1: using network backup set
from service TWELVE
destination for restore of datafile 00005:
/u01/app/oracle/oradata/TWELVE/example01.dbf
channel ORA_DISK_1: restore complete, elapsed
time: 00:00:07
channel ORA_DISK_1: starting incremental
datafile backup set restore
channel ORA_DISK_1: using network backup set
from service TWELVE
destination for restore of datafile 00006:
/u01/app/oracle/oradata/TWELVE/users01.dbf
channel ORA_DISK_1: restore complete, elapsed
time: 00:00:01
starting media recovery
archived log for thread 1 with sequence 87 is
already on disk as file
/u01/app/oracle/product/12.1.0/dbhome_1/dbs/arch1_87_910395669.dbf
archived log for thread 1 with sequence 88 is
already on disk as file /u01/app/oracle/product/12.1.0/dbhome_1/dbs/arch1_88_910395669.dbf
archived log for thread 1 with sequence 89 is
already on disk as file
/u01/app/oracle/product/12.1.0/dbhome_1/dbs/arch1_89_910395669.dbf
media recovery complete, elapsed time:
00:00:00
Finished recover at 25-APR-16
RMAN>
4. Start the recovery Check the status again;
SQL> alter database recover managed standby database using
current logfile disconnect from session;
Database altered.
SQL> SELECT distinct PROCESS, STATUS, THREAD#, SEQUENCE# FROM
V$MANAGED_STANDBY order by process;
PROCESS STATUS THREAD#
SEQUENCE#
--------- ------------ ---------- ----------
ARCH CLOSING
1 82
ARCH CLOSING
1 89
ARCH CONNECTED
0 0
MRP0 WAIT_FOR_GAP
1 86
RFS IDLE
0 0
RFS IDLE
1 90
6 rows selected.
SQL>
***As you see, standby is still waiting 86th archivelog because
controlfile doesnt know the new SCN values of the datafiles yet. So, we need to
restore the controlfile too.
5. Restore standby
controlfile from network service
SQL> alter database recover managed standby database cancel;
Database altered.
SQL> shu immediate;
ORA-01109: database not open
Database dismounted.
ORACLE instance shut down.
SQL> startup nomount;
ORACLE instance started.
Total System Global Area 926941184 bytes
Fixed Size
2930944 bytes
Variable Size
343934720 bytes
Database Buffers 574619648
bytes
Redo Buffers
5455872 bytes
SQL>
[oracle@rent ~]$ rman target /
Recovery Manager: Release 12.1.0.2.0 - Production on Mon Apr 25
21:23:20 2016
Copyright (c) 1982, 2014, Oracle and/or its affiliates.
All rights reserved.
connected to target database: TWELVE (not mounted)
RMAN> restore standby controlfile from service TWELVE;
Starting restore at 25-APR-16
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=12 device type=DISK
channel ORA_DISK_1: starting datafile backup set restore
channel ORA_DISK_1: using network backup set from service TWELVE
channel ORA_DISK_1: restoring control file
channel ORA_DISK_1: restore complete, elapsed time: 00:00:01
output file name=/u01/app/oracle/oradata/TWELVE/control01.ctl
output file name=/u01/app/oracle/oradata/TWELVE/control02.ctl
Finished restore at 25-APR-16
RMAN> alter database mount;
Statement processed
released channel: ORA_DISK_1
RMAN> alter database recover managed standby database using
current logfile disconnect from session;
Statement processed
SQL> SELECT distinct PROCESS, STATUS, THREAD#, SEQUENCE# FROM
V$MANAGED_STANDBY order by process;
PROCESS STATUS THREAD#
SEQUENCE#
--------- ------------ ---------- ----------
ARCH CONNECTED
0 0
MRP0 APPLYING_LOG
1 90
RFS IDLE
0 0
RFS IDLE
1 90
SQL>