oracle 19c adg GAP恢复

oracle 19c adg GAP恢复

继上篇文章,回退成功后。发现我们在回退的过程中,为了不影响备库,把log\_archive\_dest\_state\_2设置为了defer。但是后面想想,已经来不及了,因为主库刷新数据字典的过程中,已经会把字典的变化同步到了备库。我们设置defer的时间迟了,应该在刷新数据字典之前,就把log\_archive\_dest\_state\_2设置为defer,让备库不会应用数据字典的变化。如果此时发生切换,switchover肯定不行,failover的时候,直接把备库切换为主库,这也不失为一种好的回退方法。
本篇文章不讨论回退方法,由于设置为了defer,恢复时间用了将近8h,主库的归档删除策略是华为的备份软件强制删除,所以导致备库缺少归档,adg同步异常。下面就说下恢复方法。

故障现象

环境信息:
2节点RAC,GI和DB的补丁应用到2020年10月份。数据库版本:19.9.0.0.0
os版本:RHEL 7.6
备库adg同步信息如下:

SQL> set pages 1000 lines 1000
SQL> SELECT al.thrd "Thread", almax "Last Seq Received", lhmax "Last Seq Applied"
FROM (select thread# thrd, MAX(sequence#) almax
FROM v$archived_log
WHERE resetlogs_change#=(SELECT resetlogs_change# FROM v$database) GROUP BY thread#) al,
(SELECT thread# thrd,   2    3    4    5  MAX(sequence#) lhmax
FROM v$log_history
WHERE resetlogs_change#=(SELECT resetlogs_change# FROM v$database) GROUP BY thread#) lh
WHERE al.thrd = lh.thrd;  6    7    8

    Thread Last Seq Received Last Seq Applied
---------- ----------------- ----------------
     1           32301        32262
     2           28725        28700
SQL> col client_pid for a10
SELECT inst_id, thread#, process, pid, status, client_process, client_pid,
sequence#, block#, active_agents, known_agents FROM gv$managed_standby ORDER BY thread#, pid;SQL>   2

   INST_ID    THREAD# PROCESS    PID             STATUS       CLIENT_P CLIENT_PID  SEQUENCE#     BLOCK# ACTIVE_AGENTS KNOWN_AGENTS
---------- ---------- --------- ------------------------ ------------ -------- ---------- ---------- ---------- ------------- ------------
     1        0 RFS    30765             IDLE          UNKNOWN  35906           0          0         0         0
     1        0 RFS    30767             IDLE          UNKNOWN  142075           0          0         0         0
     1        0 RFS    30769             IDLE          UNKNOWN  35888           0          0         0         0
     1        0 RFS    30774             IDLE          UNKNOWN  141997           0          0         0         0
     1        0 RFS    30776             IDLE          UNKNOWN  142133           0          0         0         0
     1        0 RFS    30778             IDLE          UNKNOWN  35867           0          0         0         0
     1        0 DGRD    31472             ALLOCATED    N/A      N/A           0          0         0         0
     1        0 DGRD    31474             ALLOCATED    N/A      N/A           0          0         0         0
     2        0 DGRD    85340             ALLOCATED    N/A      N/A           0          0         0         0
     2        0 DGRD    85344             ALLOCATED    N/A      N/A           0          0         0         0
     1        1 MRP0    101677             WAIT_FOR_GAP N/A      N/A           32263          0       128           128
     1        1 RFS    28815             IDLE          Archival 141782           0          0         0         0
     1        1 RFS    28906             IDLE          LGWR     136732           32302     398785         0         0
     1        2 RFS    28820             IDLE          Archival 35812           0          0         0         0
     1        2 RFS    28912             IDLE          LGWR     91132           28726      10390         0         0
     1        2 ARCH    31470             CLOSING      ARCH     31470           28698      81920         0         0
     1        2 ARCH    31478             CLOSING      ARCH     31478           28700          1         0         0
     1        2 ARCH    31480             CLOSING      ARCH     31480           28699      18432         0         0
     1        2 ARCH    31482             CLOSING      ARCH     31482           28701      28672         0         0
     2        2 ARCH    85325             CLOSING      ARCH     85325           24857      36864         0         0
     2        2 ARCH    85377             CLOSING      ARCH     85377           24852      22528         0         0
     2        2 ARCH    85379             CLOSING      ARCH     85379           24855          1         0         0
     2        2 ARCH    85381             CLOSING      ARCH     85381           24853      26624         0         0

23 rows selected.
SQL> select * from v$archive_gap;

   THREAD# LOW_SEQUENCE# HIGH_SEQUENCE#     CON_ID
---------- ------------- -------------- ----------
     1       32263      32284      1

可见我们现在缺少thread 1的seq 32263-32284之间21个归档日志。

故障分析

参考前面的文章:https://www.modb.pro/db/175815#\_405
恢复GAP有两种方法:
一、gap较少,或者归档日志还存在,或者可以从备份集中恢复出来可以直接将缺少的归档scp到standby,在standby手工注册下即可。
二、gap较多,在primary 做基于scn的backup,同时创建一个新的standbycontrolfile,将备份好的backupset ,standby controlfile 拷贝到备库的相应目录下,进行restore、recover的操作即可。
此处的GAP较少,可以采用恢复出删除的归档日志进行恢复。但是前提要由备份,和要能恢复出来。
主要以下两个命令:
RMAN> list archivelog from sequence 32263 until sequence 32284 thread 1;
RMAN> list backup of archivelog from sequence 32263 until sequence 32284 thread 1;
c397da86d76e64b9d5ae75be01bb80f.jpg
44cc332966a4f119fa902d6c9fe9d8f.jpg
可见归档日志确实被删除,但是这些归档日志都已经被备份了。我们可以尝试从备份集中恢复出这些被删除的归档日志。
先尝试恢复一个:
edb0442c93aff413a4b37743b58bca9.png
恢复报错。由于没有写parms参数。
经咨询,备份采用的是华为备份软件DPA。华为自己的维护人员也不知道应该怎么恢复,而且只能全量恢复,不能恢复单个归档日志。此处吐槽一下,不知道是现场人员的问题还是DPA本身的问题,对于不能恢复单个归档日志,实在是不应该,这是最常用的场景。如果这里有熟悉DPA的人,也可以和我沟通下,怎么恢复。
类似nbu恢复这种,就可以正常恢复:
image.png
所以此处不再考虑恢复删除的归档日志恢复,采用基于scn的增量备份恢复的方案来恢复ADG GAP。

GAP恢复

参考mos:18c Roll Forward Physical Standby Using RMAN Incremental Backup in Single Command (Doc ID 2431311.1)
12c之后恢复ADG的GAP步骤简单了,有新特性了。
Typically, when rolling forward a physical standby database using primary incremental backup, multiple steps are required:

Identify the Start SCN on Standby for performing incremental backup on primary
Perform incremental backup on primary with FROM SCN clause
Move the backup-pieces from primary to standby
Catalog the backup-piece on Standby
Perform recovery on standby using recover database noredo
Refresh standby controlfile again from primary

Starting from 12.1, we could use "RECOVER DATABASE FROM SERVICE"command which will automate a few steps like performing incremental backup on primary, transfer the backup-pieces to standby over network and perform recovery on standby. However, we still had to manually refresh the standby controlfile and manually restore newly-added datafiles. These steps required manual efforts and are error prone especially when standby files are physically located in a path different to that of primary.

Starting with 18.1, we can use a single command to refresh the standby with changes made on primary:

RMAN> RECOVER STANDBY DATABASE FROM SERVICE primary\_connect\_identifier;

This command will internally keep track of standby file locations, refresh standby controlfile from primary, update the new standby controlfile with standby file names, perform incremental backup on primary, transfer the backup-pieces over network to standby and perform recovery on standby
**12.1之前,主要的恢复步骤,参考之前的文章。
12.1之后,需要recover database from service ,然后重新恢复控制文件,恢复新增数据文件。
18.1之后,更简单了,直接一条命令就包括了所有的恢复步骤。**

正式开始前需要注意两个地方
1、确认主库的TNS已配置,这里的< PRIMARY DB SERVICE NAME >即 TNSNAME。
2、If the standby is RAC with more than one instance, make sure only the instance from which recover standby command will be executed is mounted and all other instances are shutdown to avoid RMAN-05157。
必须保证出恢复节点外,剩余节点的实例都是关闭状态。否则报错RMAN-05157.这其实和手动duplicate的时候的要求一致。

RMAN> recover standby database from service priqhrimdb;
Starting recover at 2022-01-18 20:35:02
RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-03002: failure of recover command at 01/18/2022 20:35:03
RMAN-05157: The database must not be mounted on any other instance for RECOVER STANDBY DATABASE command.

具体步骤如下:

  1. 执行增量恢复
  2. 启动mrp,open数据库
  3. 修改standby日志和redo log没有转化过来的文件路径
  4. 启动mrp
  5. 检查同步状态
  • 执行增量恢复
    RMAN> recover standby database from service priqhrimdb;
qhrimdb1:/oracle/app/oracle/product/19.0.0/db/network/admin(qhrimdb1)$rman target /

Recovery Manager: Release 19.0.0.0.0 - Production on Tue Jan 18 20:51:36 2022
Version 19.9.0.0.0

Copyright (c) 1982, 2019, Oracle and/or its affiliates.  All rights reserved.

connected to target database: QHRIMDB (DBID=1354654563)

RMAN>  recover standby database from service priqhrimdb;

Starting recover at 2022-01-18 20:51:43

Oracle instance started

Total System Global Area  387620796704 bytes

Fixed Size                    30951712 bytes
Variable Size             112541564928 bytes
Database Buffers          274877906944 bytes
Redo Buffers                 170373120 bytes

contents of Memory Script:
{
   restore standby controlfile from service  'priqhrimdb';  --重新恢复控制文件
   alter database mount standby database;
}
executing Memory Script

Starting restore at 2022-01-18 20:52:06
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=3188 instance=qhrimdb1 device type=DISK

channel ORA_DISK_1: starting datafile backup set restore
channel ORA_DISK_1: using network backup set from service priqhrimdb
channel ORA_DISK_1: restoring control file
channel ORA_DISK_1: restore complete, elapsed time: 00:00:04
output file name=+DATADG1/QHRIMDB/CONTROLFILE/control_files01.ctl
Finished restore at 2022-01-18 20:52:12

released channel: ORA_DISK_1
Statement processed
Executing: alter system set standby_file_management=manual
RMAN-05529: warning: DB_FILE_NAME_CONVERT resulted in invalid ASM names; names changed to disk group only.
contents of Memory Script:
{
set newname for tempfile  1 to
 "+DATADG1/QHRIMDBSTD/TEMPFILE/temp.315.1048266439";
set newname for tempfile  2 to
 "+DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/TEMPFILE/temp.316.1048266441";
set newname for tempfile  3 to
 "+DATADG1/QHRIMDBSTD/ABF515494C5840B0E053243DE60ADF28/TEMPFILE/temp.339.1048266865";
.........
contents of Memory Script:
{
set newname for tempfile  1 to
 "+DATADG1/QHRIMDBSTD/TEMPFILE/temp.315.1048266439";
set newname for tempfile  2 to
 "+DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/TEMPFILE/temp.316.1048266441";
set newname for tempfile  3 to
 "+DATADG1/QHRIMDBSTD/ABF515494C5840B0E053243DE60ADF28/TEMPFILE/temp.339.1048266865";
.........
set newname for datafile  483 to
 "+DATADG2/QHRIMDBSTD/DATAFILE/undotbs2.396.1094268467";
set newname for datafile  484 to
 "+DATADG2/QHRIMDBSTD/DATAFILE/sysaux.397.1094268911";
   catalog datafilecopy  "+DATADG1/QHRIMDBSTD/DATAFILE/system.287.1048266159",
 "+DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/DATAFILE/system.278.1048266179",
 "+DATADG1/QHRIMDBSTD/DATAFILE/sysaux.267.1048266165",
 "+DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/DATAFILE/sysaux.281.1048266177",
..........
 "+DATADG2/QHRIMDBSTD/B198F463B60BD808E053243DE60AC13B/DATAFILE/tbs_roam_data.395.1093864019",
 "+DATADG2/QHRIMDBSTD/DATAFILE/undotbs2.396.1094268467",
 "+DATADG2/QHRIMDBSTD/DATAFILE/sysaux.397.1094268911";
   switch datafile all;                              --刷新控制文件中,修改备库控制文件中数据文件路径
}
executing Memory Script

executing command: SET NEWNAME

executing command: SET NEWNAME
.........
executing command: SET NEWNAME

cataloged datafile copy
datafile copy file name=+DATADG1/QHRIMDBSTD/DATAFILE/system.287.1048266159 RECID=1 STAMP=1094331155
cataloged datafile copy
datafile copy file name=+DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/DATAFILE/system.278.1048266179 RECID=2 STAMP=1094331155
cataloged datafile copy
datafile copy file name=+DATADG1/QHRIMDBSTD/DATAFILE/sysaux.267.1048266165 RECID=3 STAMP=1094331155
..........
datafile 1 switched to datafile copy
input datafile copy RECID=1 STAMP=1094331155 file name=+DATADG1/QHRIMDBSTD/DATAFILE/system.287.1048266159
datafile 2 switched to datafile copy
input datafile copy RECID=2 STAMP=1094331155 file name=+DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/DATAFILE/system.278.1048266179
datafile 3 switched to datafile copy
input datafile copy RECID=3 STAMP=1094331155 file name=+DATADG1/QHRIMDBSTD/DATAFILE/sysaux.267.1048266165
.........
datafile 484 switched to datafile copy
input datafile copy RECID=418 STAMP=1094331169 file name=+DATADG2/QHRIMDBSTD/DATAFILE/sysaux.397.1094268911
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_5.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_5.258.1048266211'
Oracle error from target database:
ORA-19528: redo logs being cleared may need access to files
RMAN-05535: warning: All redo log files were not defined properly.
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_6.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_6.259.1048266215'
Oracle error from target database:
ORA-19528: redo logs being cleared may need access to files
RMAN-05535: warning: All redo log files were not defined properly.
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_7.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_7.271.1048266219'
Oracle error from target database:
ORA-19528: redo logs being cleared may need access to files
RMAN-05535: warning: All redo log files were not defined properly.
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_8.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_8.296.1048266223'
Oracle error from target database:
ORA-19528: redo logs being cleared may need access to files
RMAN-05535: warning: All redo log files were not defined properly.
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_9.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_9.295.1048266227'
Oracle error from target database:
ORA-19528: redo logs being cleared may need access to files
RMAN-05535: warning: All redo log files were not defined properly.
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_10.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_10.294.1048266233'
Oracle error from target database:
ORA-19528: redo logs being cleared may need access to files
RMAN-05535: warning: All redo log files were not defined properly.
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_11.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_11.293.1048266237'
Oracle error from target database:
ORA-19528: redo logs being cleared may need access to files
RMAN-05535: warning: All redo log files were not defined properly.
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_12.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_12.270.1048266241'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_13.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_13.291.1048266245'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_14.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_14.290.1048266249'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_15.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_15.286.1048266255'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_16.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_16.284.1048266259'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_17.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_17.279.1048266263'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_18.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_18.275.1048266267'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_19.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_19.274.1048266271'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_20.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_20.273.1048266277'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_21.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_21.269.1048266281'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_22.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_22.268.1048266285'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_23.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_23.265.1048266289'
Executing: alter database rename file '+DATADG1/MUST_RENAME_THIS_LOGFILE_24.4294967295.4294967295' to '+DATADG1/QHRIMDBSTD/ONLINELOG/group_24.264.1048266293'
contents of Memory Script:
{
  recover database from service  'priqhrimdb';    --直接在线进行增量备份和恢复。
}
executing Memory Script
Starting recover at 2022-01-18 20:57:06
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=1594 instance=qhrimdb1 device type=DISK
channel ORA_DISK_1: starting incremental datafile backup set restore
channel ORA_DISK_1: using network backup set from service priqhrimdb
destination for restore of datafile 00001: +DATADG1/QHRIMDBSTD/DATAFILE/system.287.1048266159
channel ORA_DISK_1: restore complete, elapsed time: 00:00:04
channel ORA_DISK_1: starting incremental datafile backup set restore
channel ORA_DISK_1: using network backup set from service priqhrimdb
destination for restore of datafile 00002: +DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/DATAFILE/system.278.1048266179
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 backup set from service priqhrimdb
destination for restore of datafile 00003: +DATADG1/QHRIMDBSTD/DATAFILE/sysaux.267.1048266165
channel ORA_DISK_1: restore complete, elapsed time: 00:00:01
..............
channel ORA_DISK_1: restore complete, elapsed time: 00:00:15
channel ORA_DISK_1: starting incremental datafile backup set restore
channel ORA_DISK_1: using network backup set from service priqhrimdb
destination for restore of datafile 00484: +DATADG2/QHRIMDBSTD/DATAFILE/sysaux.397.1094268911
channel ORA_DISK_1: restore complete, elapsed time: 00:00:15
starting media recovery
archived log for thread 1 with sequence 32307 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32307.1018.1094332275
archived log for thread 1 with sequence 32308 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32308.1084.1094334077
archived log for thread 1 with sequence 32309 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32309.1047.1094335877
archived log for thread 1 with sequence 32310 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32310.923.1094335885
archived log for thread 1 with sequence 32311 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32311.1010.1094335889
archived log for thread 2 with sequence 28731 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28731.1000.1094332275
archived log for thread 2 with sequence 28732 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28732.1007.1094334077
archived log for thread 2 with sequence 28733 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28733.1077.1094335877
archived log for thread 2 with sequence 28734 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28734.1092.1094335885
archived log for thread 2 with sequence 28735 is already on disk as file +ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28735.332.1094335889
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32307.1018.1094332275 thread=1 sequence=32307
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28731.1000.1094332275 thread=2 sequence=28731
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32308.1084.1094334077 thread=1 sequence=32308
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28732.1007.1094334077 thread=2 sequence=28732
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32309.1047.1094335877 thread=1 sequence=32309
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28733.1077.1094335877 thread=2 sequence=28733
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28734.1092.1094335885 thread=2 sequence=28734
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32310.923.1094335885 thread=1 sequence=32310
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_1_seq_32311.1010.1094335889 thread=1 sequence=32311
archived log file name=+ARCHIVEDG/QHRIMDBSTD/ARCHIVELOG/2022_01_18/thread_2_seq_28735.332.1094335889 thread=2 sequence=28735
media recovery complete, elapsed time: 00:00:21
Finished recover at 2022-01-18 22:30:37
Executing: alter system set standby_file_management=auto
Finished recover at 2022-01-18 22:30:37

可以看到,此命令执行后,分别执行了如下过程:
This command will internally keep track of standby file locations, refresh standby controlfile from primary, update the new standby controlfile with standby file names, perform incremental backup on primary, transfer the backup-pieces over network to standby and perform recovery on standby。
熟悉复制duplicate的人都可以看出,此过程和duplicate adg的过程极为相似。
从输出可以看出,过程分为以下三个部分:
1、重新恢复备库控制文件,启动standby到mount状态
contents of Memory Script:
{
restore standby controlfile from service ‘priqhrimdb’;
alter database mount standby database;
}
2、修改standby控制文件中数据库文件路径,包括临时文件和redo log,datafile。
虽然primary和standby之间路径并不相同,但是在参数文件中已经通过db\_file\_name\_convert,log\_file\_name\_convert等初始化参数的方式重定义数据文件和日志文件路径,因此执行复制时,不需要指定其他子句或命令进行转化。
contents of Memory Script:
{
set newname for tempfile 1 to
“+DATADG1/QHRIMDBSTD/TEMPFILE/temp.315.1048266439”;
set newname for tempfile 2 to
“+DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/TEMPFILE/temp.316.1048266441”;
。。。。。
set newname for datafile 484 to
“+DATADG2/QHRIMDBSTD/DATAFILE/sysaux.397.1094268911”;
catalog datafilecopy “+DATADG1/QHRIMDBSTD/DATAFILE/system.287.1048266159”,
“+DATADG1/QHRIMDBSTD/AAC3F48E60DFEF9CE053243DE60AC007/DATAFILE/system.278.1048266179”,
。。。。。
“+DATADG2/QHRIMDBSTD/DATAFILE/undotbs2.396.1094268467”,
“+DATADG2/QHRIMDBSTD/DATAFILE/sysaux.397.1094268911”;
switch datafile all;
}
3、在线增量备份,和恢复。没看到增量备份的过程,只有增量恢复的过程。
contents of Memory Script:
{
recover database from service ‘priqhrimdb’;
}

  • 启动mrp,open数据库
SQL> recover managed standby database using current logfile disconnect;
Media recovery complete.
SQL> recover managed standby database cancel;
Media recovery complete.
SQL> alter database open;
Database altered.
  • 修改standby日志路径
    查看redo和standby日志路径,重建路径错误的日志。
  G  T STATUS      TYPE            M STATUS     FIRST_CHANGE# NEXT_CHANGE# MEMBER                             First Time
--- -- ---------- ---------- -------- ---------- ------------- ------------ ------------------------------------------------------------ -------------------
  5  1 UNUSED      ONLINE     4096            1.5349E+13     1.5349E+13 +DATADG1/QHRIMDBSTD/ONLINELOG/group_5.662.1094337555     20220118 18:11:06
     1 UNUSED      ONLINE     4096            1.5349E+13     1.5349E+13 +DATADG2/QHRIMDBSTD/ONLINELOG/group_5.420.1094337563     20220118 18:11:06
.........
 13  1 UNUSED      ONLINE     4096            1.5349E+13     1.5349E+13 +DATADG1/QHRIMDBSTD/ONLINELOG/group_13.291.1094337661     20220118 18:11:03
     1 UNUSED      ONLINE     4096            1.5349E+13     1.5349E+13 +DATADG2/QHRIMDBSTD/ONLINELOG/group_13.429.1094337669     20220118 18:11:03
 14  1 UNUSED      ONLINE     4096            1.5349E+13     1.5349E+13 +DATADG1/QHRIMDBSTD/ONLINELOG/group_14.290.1094337675     20220118 18:11:04
     1 UNUSED      ONLINE     4096            1.5349E+13     1.5349E+13 +DATADG2/QHRIMDBSTD/ONLINELOG/group_14.430.1094337681     20220118 18:11:04
 91  1 ACTIVE      STANDBY     4096            1.5349E+13            +DATADG1/QHRIMDBSTD/ONLINELOG/group_91.651.1094331283     20220118 22:41:26
     1 ACTIVE      STANDBY     4096            1.5349E+13            +DATADG2/QHRIMDBSTD/ONLINELOG/group_91.409.1094331289     20220118 22:41:26
 92  1 UNASSIGNED STANDBY     4096                        +DATADG1/QHRIMDBSTD/ONLINELOG/group_92.652.1094331295
     1 UNASSIGNED STANDBY     4096                        +DATADG2/QHRIMDBSTD/ONLINELOG/group_92.410.1094331301
.........
 99  1 UNASSIGNED STANDBY     4096                        +DATADG2/QHRIMDBSTD/ONLINELOG/group_99.417.1094331393
     1 UNASSIGNED STANDBY     4096                        +DATADG1/QHRIMDBSTD/ONLINELOG/group_99.659.1094331387
###  1 UNASSIGNED STANDBY     4096                        +DATADG1/QHRIMDBSTD/ONLINELOG/group_100.660.1094331399
     1 UNASSIGNED STANDBY     4096                        +DATADG2/QHRIMDBSTD/ONLINELOG/group_100.418.1094331407
###  1 UNASSIGNED STANDBY     4096                        +DATADG1/QHRIMDBSTD/ONLINELOG/group_101.661.1094331413
     1 UNASSIGNED STANDBY     4096                        +DATADG2/QHRIMDBSTD/ONLINELOG/group_101.419.1094331419
 15  2 UNUSED      ONLINE     4096            1.5349E+13     1.5349E+13 +DATADG1/QHRIMDBSTD/ONLINELOG/group_15.286.1094337687     20220118 18:11:05
     2 UNUSED      ONLINE     4096            1.5349E+13     1.5349E+13 +DATADG2/QHRIMDBSTD/ONLINELOG/group_15.431.1094337695     20220118 18:11:05
 ........
 24  2 CLEARING   ONLINE     4096 INVALID        1.5349E+13     1.5349E+13 +DATADG1/QHRIMDBSTD/ONLINELOG/group_24.264.1094337805     20220118 18:10:59
     2 CLEARING   ONLINE     4096 INVALID        1.5349E+13     1.5349E+13 +DATADG2                             20220118 18:10:59
###  2 UNASSIGNED STANDBY     4096                        +DATADG1/QHRIMDBSTD/ONLINELOG/group_102.641.1094331153
     2 UNASSIGNED STANDBY     4096                        +DATADG2/QHRIMDBSTD/ONLINELOG/group_102.399.1094331161
###  2 ACTIVE      STANDBY     4096            1.5349E+13            +DATADG1/QHRIMDBSTD/ONLINELOG/group_103.642.1094331167     20220118 22:41:29
     2 ACTIVE      STANDBY     4096            1.5349E+13            +DATADG2/QHRIMDBSTD/ONLINELOG/group_103.400.1094331175     20220118 22:41:29
.........
84 rows selected.

如上结果,只有group24 ,有一组成员没有转化过来。我们此处选择重建,即删除,重新创建。有人担心重建会出问题,但是注意,这里是standby端,只读状态,redo log根本就用不到,standby log只是用来接收存储主库的日志,即使删掉,数据库也可以重新接收。所以此处放心大胆的重建。

SQL> alter system set standby_file_management=manual;
System altered.
SQL> alter database drop logfile group 24;
alter database drop logfile group 24
*
ERROR at line 1:
ORA-19528: redo logs being cleared may need access to files
SQL> alter database clear logfile group 24;
Database altered.
SQL> alter database drop logfile group 24;
Database altered.
SQL>  alter database add logfile thread 2 '+DATADG1','+DATADG2' size 4294967296;
Database altered.
  1. 启动mrp
SQL> recover managed standby database using current logfile disconnect;
Media recovery complete.
  1. 检查同步状态
SQL> alter system set standby_file_management=auto;
System altered.
SQL> SELECT al.thrd "Thread", almax "Last Seq Received", lhmax "Last Seq Applied"
FROM (select thread# thrd, MAX(sequence#) almax
FROM v$archived_log
WHERE resetlogs_change#=(SELECT resetlogs_change# FROM v$database) GROUP BY thread#) al,
(SELECT thread# thrd,   2    3    4    5  MAX(sequence#) lhmax
FROM v$log_history
WHERE resetlogs_change#=(SELECT resetlogs_change# FROM v$database) GROUP BY thread#) lh
WHERE al.thrd = lh.thrd;  6    7    8
    Thread Last Seq Received Last Seq Applied
---------- ----------------- ----------------
     1           32312        32312
     2           28736        28736
SQL> col client_pid for a10
SELECT inst_id, thread#, process, pid, status, client_process, client_pid,
sequence#, block#, active_agents, known_agents FROM gv$managed_standby ORDER BY thread#, pid;SQL>   2
  I  T PROCESS     PID              STATUS     CLIENT_P CLIENT_PID  SEQUENCE#    BLOCK# ACTIVE_AGENTS KNOWN_AGENTS
--- -- --------- ------------------------ ---------- -------- ---------- ---------- ---------- ------------- ------------
  1  0 DGRD     136580           ALLOCATED  N/A      N/A          0         0           0        0
  1  0 DGRD     136582           ALLOCATED  N/A      N/A          0         0           0        0
  1  1 RFS     105736           IDLE         LGWR     136697          32313    182495           0        0
  1  1 ARCH     136590           CLOSING    ARCH     136590          32312    743424           0        0
  1  1 RFS     163497           IDLE         Archival 141782          0         0           0        0
  1  2 RFS     106402           IDLE         LGWR     91071          28737      3906           0        0
  1  2 ARCH     136578           CLOSING    ARCH     136578          28735         1           0        0
  1  2 ARCH     136588           CLOSING    ARCH     136588          28736    126976           0        0
  1  2 ARCH     136596           CLOSING    ARCH     136596          28734         1           0        0
  1  2 RFS     137702           IDLE         Archival 35812          0         0           0        0
  1  2 MRP0     40547              APPLYING_L N/A      N/A          28737      3906         128          128
                      OG
11 rows selected.

至此,恢复完成,ADG同步状态正常。

总结

优势:
1、18c之后,如果没有有效的归档日志,恢复ADG的GAP,只需要一条命令就可以完成。替代了以前繁琐的过程,但是要清楚这条命令包含的许多东西,其实原理和之前的增量备份恢复一摸一样,只是多个步骤被集成为了一条命令可见随着oracle版本的升级,越来愈自动化了。
2、节省空间,再也不用担心primary和standby要有额外空间来存储增量备份集了。特别对于库比较大,GAP比较大的。增量备份集所需空间很大。
3、通过网络在线传输,不用手动在主备之间进行备份集传输了。
劣势:
对版本有要求,要18c之后的版本才支持。

参考

Rolling Forward a Physical Standby Using Recover From Service Command in 12c (Doc ID 1987763.1)
18c Roll Forward Physical Standby Using RMAN Incremental Backup in Single Command (Doc ID 2431311.1)

你可能感兴趣的:(rmanoracle恢复数据)