在Nocatalog的情况下,硬盘上的Rman备份集在使用一次后,控制文件发生了变化。
不但备份集中控制文件的文件时间发生了变化,我猜想内容也发生了变化。
之后再次使用这个备份集进行恢复操作,碰到错误。
本文记录了这个过程,以及如何解决。
恢复orapw文件 :
[Oracle@shdemo1 dbs]$ orapwd file=orapwdevb passWord=123456 entries=20 [oracle@shdemo1 dbs]$ [oracle@shdemo1 dbs]$ sqlplus /nolog
SQL*Plus: Release 9.2.0.4.0 - ProdUCtion on Wed May 10 15:54:49 2006
Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.
SQL> conn sys/123456@devb as sysdba Connected to an idle instance. SQL> startup nomount ORA-01031: insufficient privileges SQL> SQL> disc Disconnected SQL> conn / as sysdba Connected to an idle instance. SQL> SQL> startup nomount ORACLE instance started.
Total System Global Area 42742804 bytes Fixed Size 451604 bytes Variable Size 41943040 bytes Database Buffers 204800 bytes Redo Buffers 143360 bytes SQL>
恢复 spfile:
[oracle@shdemo1 devb]$ rman nocatalog
Recovery Manager: Release 9.2.0.4.0 - Production
Copyright (c) 1995, 2002, Oracle Corporation. All rights reserved.
RMAN> connect target
connected to target database: devb (not mounted) using target database controlfile instead of recovery catalog
RMAN> set DBID=1179520070
executing command: SET DBID
RMAN> restore spfile from autobackup;
Starting restore at 10-MAY-06
allocated channel: ORA_DISK_1 channel ORA_DISK_1: sid=10 devtype=DISK channel ORA_DISK_1: looking for autobackup on day: 20060510 channel ORA_DISK_1: looking for autobackup on day: 20060509 channel ORA_DISK_1: looking for autobackup on day: 20060508 channel ORA_DISK_1: looking for autobackup on day: 20060507 channel ORA_DISK_1: looking for autobackup on day: 20060506 channel ORA_DISK_1: looking for autobackup on day: 20060505 channel ORA_DISK_1: looking for autobackup on day: 20060504 channel ORA_DISK_1: no autobackup in 7 days found RMAN-00571: =========================================================== RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS =============== RMAN-00571: =========================================================== RMAN-03002: failure of restore command at 05/10/2006 15:57:57 RMAN-06172: no autobackup found or specified handle is not a valid copy or piece
RMAN> restore spfile from '/home/oracle/backup/devb/c-1179520070-20060510-05';
Starting restore at 10-MAY-06
using channel ORA_DISK_1 channel ORA_DISK_1: autobackup found: /home/oracle/backup/devb/c-1179520070-20060510-05 channel ORA_DISK_1: SPFILE restore from autobackup complete Finished restore at 10-MAY-06
RMAN>
恢复control file:
SQL> shutdown immediate ORA-01507: database not mounted
ORACLE instance shut down. SQL> conn / as sysdba Connected to an idle instance. SQL> startup nomount ORACLE instance started.
Total System Global Area 236000356 bytes Fixed Size 451684 bytes Variable Size 201326592 bytes Database Buffers 33554432 bytes Redo Buffers 667648 bytes SQL>
[oracle@shdemo1 devb]$ [oracle@shdemo1 devb]$ [oracle@shdemo1 devb]$ rman nocatalog
Recovery Manager: Release 9.2.0.4.0 - Production
Copyright (c) 1995, 2002, Oracle Corporation. All rights reserved.
RMAN> connect target
connected to target database: devb (not mounted) using target database controlfile instead of recovery catalog
RMAN> set DBID=1179520070
executing command: SET DBID
RMAN> restore controlfile from '/home/oracle/backup/devb/c-1179520070-20060510-05';
Starting restore at 10-MAY-06
allocated channel: ORA_DISK_1 channel ORA_DISK_1: sid=14 devtype=DISK channel ORA_DISK_1: restoring controlfile channel ORA_DISK_1: restore complete replicating controlfile input filename=/usr/app/oracle/oradata/devb/control01.ctl output filename=/usr/app/oracle/oradata/devb/control02.ctl output filename=/usr/app/oracle/oradata/devb/control03.ctl Finished restore at 10-MAY-06
RMAN> restore database; .....
RMAN>alter database open resetlogs;
数据库恢复完毕。
使用RMAN恢复,打开数据库使用alter database open resetlogs;
此备份放在硬盘上,只有一份。 此时做试验,将数据库相关文件全部删除后试图用RMAN再次恢复,结果:
spfile 和 controlfile 可以恢复,但是数据文件无法恢复了: 如下所示:
RMAN> restore database;
Starting restore at 10-MAY-06
allocated channel: ORA_DISK_1 channel ORA_DISK_1: sid=14 devtype=DISK RMAN-00571: =========================================================== RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS =============== RMAN-00571: =========================================================== RMAN-03002: failure of restore command at 05/10/2006 16:21:43 RMAN-06026: some targets not found - aborting restore RMAN-06023: no backup or copy of datafile 10 found to restore RMAN-06023: no backup or copy of datafile 9 found to restore RMAN-06023: no backup or copy of datafile 8 found to restore RMAN-06023: no backup or copy of datafile 7 found to restore RMAN-06023: no backup or copy of datafile 6 found to restore RMAN-06023: no backup or copy of datafile 5 found to restore RMAN-06023: no backup or copy of datafile 4 found to restore RMAN-06023: no backup or copy of datafile 3 found to restore RMAN-06023: no backup or copy of datafile 2 found to restore RMAN-06023: no backup or copy of datafile 1 found to restore
网上查了一下,原来在尝试恢复中使用了_allow_resetlogs_corruption参数,resetlogs之后,Oracle使用当前的控制文件不答应从这个历史备份集中进行恢复。 由于我没有使用catalog,所以尝试使用dbms_backup_restore进行恢复。
[oracle@shdemo1 devb]$ sqlplus /nolog
SQL*Plus: Release 9.2.0.4.0 - Production on Wed May 10 16:29:26 2006
Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.
SQL> SQL> shutdown immediate ORA-01012: not logged on SQL> conn / as sysdba Connected. SQL> shutdown immediate ORA-01109: database not open
Database dismounted. ORACLE instance shut down. SQL> startup nomount ORACLE instance started.
Total System Global Area 236000356 bytes Fixed Size 451684 bytes Variable Size 201326592 bytes
Database Buffers 33554432 bytes Redo Buffers 667648 bytes SQL> DECLARE 2 devtype varchar2(256); 3 done boolean; 4 BEGIN 5 devtype:=sys.dbms_backup_restore.deviceAllocate (type=>'',ident=>'t1'); 6 sys.dbms_backup_restore.restoreSetDatafile; 7 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>01, toname=>'/usr/app/oracle/oradata/devb/system01.dbf'); 8 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>02, toname=>'/usr/app/oracle/oradata/devb/undotbs01.dbf'); 9 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>03, toname=>'/usr/app/oracle/oradata/devb/cwmlite01.dbf'); 10 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>04, toname=>'/usr/app/oracle/oradata/devb/drsys01.dbf'); 11 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>05, toname=>'/usr/app/oracle/oradata/devb/example01.dbf'); 12 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>06, toname=>'/usr/app/oracle/oradata/devb/indx01.dbf'); 13 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>07, toname=>'/usr/app/oracle/oradata/devb/odm01.dbf'); 14 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>08, toname=>'/usr/app/oracle/oradata/devb/tools01.dbf'); 15 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>09, toname=>'/usr/app/oracle/oradata/devb/users01.dbf'); 16 sys.dbms_backup_restore.restoreDatafileTo(dfnumber=>10, toname=>'/usr/app/oracle/oradata/devb/xdb01.dbf'); 17 sys.dbms_backup_restore.restoreBackupPiece(done=>done,handle=>'/home/oracle/backup/devb/df_DEVB_43_1_1.bak', params=>null); 18 sys.dbms_backup_restore.deviceDeallocate; 19 END; 20 /
PL/SQL procedure successfully completed.
SQL> alter database mount;
Database altered.
SQL> recover database; ORA-00283: recovery session canceled due to errors ORA-01610: recovery using the BACKUP CONTROLFILE option must be done
SQL> recover database using backup controlfile until cancel; ORA-00283: recovery session canceled due to errors ORA-01190: controlfile or data file 1 is from before the last RESETLOGS ORA-01110: data file 1: '/usr/app/oracle/oradata/devb/system01.dbf'
SQL> SQL> SQL> SQL> SQL> alter database backup controlfile to trace;
Database altered.
SQL>
原来的controlfile 已不能使用,所以重建controlfile;
trace文件在 user_dump_desc 下。
即 /usr/app/oracle/admin/devb/udump 找到最新的trc文件 SQL> SQL> shutdown immediate ORA-01109: database not open
Database dismounted. ORACLE instance shut down. SQL> startup nomount ORACLE instance started.
Total System Global Area 236000356 bytes Fixed Size 451684 bytes Variable Size 201326592 bytes Database Buffers 33554432 bytes Redo Buffers 667648 bytes SQL> SQL> CREATE CONTROLFILE REUSE DATABASE "DEVB" RESETLOGS ARCHIVELOG 2 -- SET STANDBY TO MAXIMIZE PERFORMANCE 3 MAXLOGFILES 50 4 MAXLOGMEMBERS 5 5 MAXDATAFILES 100 6 MAXINSTANCES 1 7 MAXLOGHISTORY 226 8 LOGFILE 9 GROUP 1 '/usr/app/oracle/oradata/devb/redo01.log' SIZE 100M, 10 GROUP 2 '/usr/app/oracle/oradata/devb/redo02.log' SIZE 100M, 11 GROUP 3 '/usr/app/oracle/oradata/devb/redo03.log' SIZE 100M 12 -- STANDBY LOGFILE 13 DATAFILE 14 '/usr/app/oracle/oradata/devb/system01.dbf', 15 '/usr/app/oracle/oradata/devb/undotbs01.dbf', 16 '/usr/app/oracle/oradata/devb/cwmlite01.dbf', 17 '/usr/app/oracle/oradata/devb/drsys01.dbf', 18 '/usr/app/oracle/oradata/devb/example01.dbf', 19 '/usr/app/oracle/oradata/devb/indx01.dbf', 20 '/usr/app/oracle/oradata/devb/odm01.dbf', 21 '/usr/app/oracle/oradata/devb/tools01.dbf', 22 '/usr/app/oracle/oradata/devb/users01.dbf', 23 '/usr/app/oracle/oradata/devb/xdb01.dbf' 24 CHARACTER SET ZHS16GBK 25 ;
Control file created.
SQL> recover database; ORA-00283: recovery session canceled due to errors ORA-01610: recovery using the BACKUP CONTROLFILE option must be done
SQL> recover database using backup controlfile until cancel; ORA-00279: change 20469549 generated at 05/10/2006 11:52:29 needed for thread 1 ORA-00289: suggestion : /usr/app/oracle/product/9.2.0.4/dbs/arch1_3.dbf ORA-00280: change 20469549 for thread 1 is in sequence #3
Specify log: {<
RET>=suggested filename AUTO CANCEL} CANCEL Media recovery cancelled. SQL> SQL> alter database open resetlogs;
Database altered.
SQL>
|