oracle dataguard archive gap后恢复

前端之家收集整理的这篇文章主要介绍了oracle dataguard archive gap后恢复前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

起因:源端数据库应用程序逻辑错误,导致重大量重试回滚,日产生归档300GB,异地备份在10Mbps的网速下,产生了archive gap;
解决流程:
1 查出备库当前的scn号

  1. select current_scn from v$database;
  2. 1612480746

2 在主库生成基于备库scn的增量备份

  1. --primary
  2. show all;
  3. run{
  4. ALLOCATE CHANNEL d1 TYPE disk;
  5. set limit channel d1 kbytes=104857600;
  6. BACKUP INCREMENTAL FROM SCN 1612480746 DATABASE FORMAT 'J:\%U_for_stb.bk' include current controlfile for standby;
  7. }

3 传送日志到备库

  1. --standby
  2. catalog start with 'e:\inc';

4 应用control file,增量备份集

  1. restore standby controlfile to 'e:\control01.ctl' ;
  2. shutdown immediate;
  3. copy e:\control01.ctl E:\ORADATA\TCIS\CONTROL01.CTL
  4. copy e:\control01.ctl E:\ORADATA\TCIS\CONTROL02.CTL
  5. copy e:\control01.ctl E:\ORADATA\TCIS\CONTROL03.CTL

recover database noredo;
报错:

  1. RMAN-03002: recover 命令 (在 07/08/2018 10:49:09 上) 失败
  2. RMAN-06094: 数据文件5必须重新存储

启动原先的备库,select name from v$datafile
发现文件有重新rename的;有点梗;
5 修改数据文件位置

  1. alter system set standby_file_management=manual;
  2. alter database rename file 'E:\ORADATA\TCIS\UBSS_INDX01.DBF' to 'd:\oradata\tcis\ubss_indx01.dbf';
  3. alter database rename file 'E:\ORADATA\TCIS\UBSS_INDX02.DBF' to 'd:\oradata\tcis\ubss_indx02.dbf';

6 再次recover database noredo

  1. 又报错,第16文件不存在
  2. RMAN-03002: recover 命令 (在 07/08/2018 10:49:09 上) 失败
  3. RMAN-06094: 数据文件16必须重新存储

以老的控制文件启动,发现第16号文件是之后添加
7 主库上备份16号文件
backup datafile 16 format 'j:\16.bak';
8 备库上恢复16文件

  1. --primary
  2. catalog start with 'e:\inc';
  3. restore datafile 16 ;
  4. recover database noredo;
  1. RMAN-03002: recover 命令 (在 07/07/2018 10:44:11 上) 失败
  2. ORA-19693: 包括备份片段 E:\INC\CDT7BHIL_1_1_FOR_STB.BK
  3. recover失败,很名显,这个16文件是之后恢复的,其scn大于之前做的备份片集

9 清理无效的备份片,再次重复2之后的步骤,backup,restore controlfile,rename datafile,recover database ;

10 恢复完成后检查
复原参数
alter system set standby_file_management=auto;
启动recover
alter database recover managed standby database disconnect;
检查日志应用情况

  1. sql> select status,blocks,process,sequence# from v$managed_standby;
  2.  
  3. STATUS BLOCKS PROCESS SEQUENCE#
  4. ------------ ---------- --------- ----------
  5. CONNECTED 0 ARCH 0
  6. CONNECTED 0 ARCH 0
  7. CONNECTED 0 ARCH 0
  8. CONNECTED 0 ARCH 0
  9. IDLE 20480 RFS 45261
  10. IDLE 20480 RFS 45262
  11. IDLE 0 RFS 0
  12. APPLYING_LOG 81560 MRP0 45248

检查归档,删除已应用的归档

  1. select a.thread#,a.sequence#,a.applied,a.name
  2. from v$archived_log a,v$database d
  3. where a.activation# = d.activation#
  4. and a.applied='YES' order by 2;

猜你在找的Oracle相关文章