|
Oracle备份与恢复案例(10) 下面分别用来说明这两种恢复方法: 5.1.2.1 通过备份来恢复 1、 打开数据库,会遇到一个类似的错误 ORA-00313: open failed for members of log group 1 of thread 1 ORA-00312: online log 1 thread 1: 'D:\Oracle\ORADATA\TEST\REDO01.LOG' ORA-27041: unable to open file OSD-04002: unable to open file O/S-Error: (OS 2) 系统找不到指定的文件 2、 查看V$log,发现是当前日志 SQL> select group#,sequence#,archived,status from v$log; GROUP# SEQUENCE# ARCHIVED STATUS --------- ---------- -------- ---------------- 1 1 NO CURRENT 2 2 YES INACTIVE 3 3 YES INACTIVE 3、 发现clear不成功 SQL> alter database clear unarchived logfile group 1; alter database clear unarchived logfile group 1 * ERROR at line 1: ORA-01624: log 1 needed for crash recovery of thread 1 ORA-00312: online log 1 thread 1: 'D:\Oracle\ORADATA\TEST\REDO01.LOG' 4、 拷贝有效的数据库的全备份,并不完全恢复数据库: 可以采用获取最近的SCN的办法用until scn恢复或用until cnacel恢复 recover database until cancel 先选择auto,尽量恢复可以利用的归档日志,然后重新 recover database until cancel 这次输入cancel,完成不完全恢复,也就是说恢复两次。 如: SQL> recover database until cancel; Auto …… SQL> recover database until cancel; Cancel; 5、 利用alter database open resetlogs打开数据库. 说明: 1、这种办法恢复的数据库是一致的不完全恢复,会丢失当前联机日志中的事务数据; 2、这种方法适合于归档数据库并且有可用的数据库全备份; 3、恢复成功之后,记得再做一次数据库的全备份; 4、建议联机日志文件一定要实现镜相在不同的磁盘上,避免这种情况的发生,因为任何数据的丢失对于生产来说都是不容许的。 5.1.2.2 如果没有备份,进行强制性恢复 1、 打开数据库,会遇到一个类似的错误 ORA-00313: open failed for members of log group 1 of thread 1 ORA-00312: online log 1 thread 1: 'D:\Oracle\ORADATA\TEST\REDO01.LOG' ORA-27041: unable to open file OSD-04002: unable to open file O/S-Error: (OS 2) 系统找不到指定的文件 2、 查看V$log,发现是当前日志 SQL> select group#,sequence#,archived,status from v$log; GROUP# SEQUENCE# ARCHIVED STATUS ---------- ---------- -------- ---------------- 1 1 NO CURRENT 2 2 YES INACTIVE 3 3 YES INACTIVE 3、 发现clear不成功 SQL> alter database clear unarchived logfile group 1; alter database clear unarchived logfile group 1 * ERROR at line 1: ORA-01624: log 1 needed for crash recovery of thread 1 ORA-00312: online log 1 thread 1: 'D:\Oracle\ORADATA\TEST\REDO01.LOG' 4、 把数据库down掉 SQL>shutdown immediate 5、 在init<sid>.ora中加入如下参数 _allow_resetlogs_corruption=TRUE 6、 重新启动数据库,利用until cancel恢复 SQL>recover database until cancel; Cancel 如果出错,不再理会,发出 SQL>alter database open resetlogs; 7、 数据库被打开后,马上执行一个full eXPort 8、 shutdown数据库,去掉_all_resetlogs_corrupt参数 9、 重建库 10、import并完成恢复 11、建议执行一下ANALYZE TABLE ...VALIDATE STRUCTURE CASCADE;
说明: 1、该恢复方法是没有办法之后的恢复方法,一般情况下建议不要采用,因为该方法可能导致数据库的不一致; 2、该方法也丢失数据,但是丢失的数据没有上一种方法的数据多,主要是未写入数据文件的已提交或未提交数据; 3、建议成功后严格执行以上的7到11步,完成数据库的检查与分析; 4、全部完成后做一次数据库的全备份; 5、建议联机日志文件一定要实现镜相在不同的磁盘上,避免这种情况的发生,因为任何数据的丢失对于生产来说都是不容许的。
5.2 损坏控制文件的恢复方法 5.2.1 损坏单个控制文件 损坏单个控制文件是比较容易恢复的,因为一般的数据库系统,控制文件都不是一个,而且所有的控制文件都互为镜相,只要拷贝一个好的控制文件替换坏的控制文件就可以了。 1、 控制文件损坏,最典型的就是启动数据库出错,不能mount数据库 SQL>startup ORA-00205: error in identifying controlfile, check alert log for more info 查看报警日志文件,有如下信息 alter database mount Mon May 26 11:59:52 2003 ORA-00202: controlfile: 'D:\Oracle\oradata\chen\control01.ctl' ORA-27041: unable to open file OSD-04002: unable to open file O/S-Error: (OS 2) 系统找不到指定的文件。 2、 停止数据库: SQL>shutdown immediate 3、 拷贝一个好的控制文件替换坏的控制文件或修改init.ora中的控制文件参数,取消这个坏的控制文件。 4、 重新启动数据: SQL>startup 说明: 1、损失单个控制文件是比较简单的,因为数据库中所有的控制文件都是镜相的,只需要简单的 拷贝一个好的就可以了; 2、建议镜相控制文件在不同的磁盘上; 3、建议多做控制文件的备份,长期保留一份由alter database backup control file to trace产生的控制文件的文本备份。
|