重做日志文件丢失导致无法打开数据库

1.模拟重做日志文件丢失:

SQL> select member from v$logfile;
MEMBER
--------------------------------------------------------------------------------
/home/oracle/data/oradata/zxin/redo01.log
/home/oracle/data/oradata/zxin/redo02.log
/home/oracle/data/oradata/zxin/redo03.log
SQL>
删除重做日志文件:
SQL> ho rm /home/oracle/data/oradata/zxin/redo0*
SQL> host
oracle@linux:~/data/oradata/zxin> ls *.log
ls: cannot access *.log: No such file or director

重做日志文件已经删除了,我们尝试重启数据库:

如图: 找不到redo02.log重做日志文件,我们如何恢复呢:

打开系统隐藏参数:

SQL> alter system set "_allow_resetlogs_corruption"=true scope=spfile;
System altered.
SQL>
重启数据库并强制到mount状态:
SQL> startup force mount;
ORACLE instance started.
Total System Global Area 1375731712 bytes
Fixed Size                               2083848 bytes
Variable Size                       402654200 bytes
Database Buffers                956301312 bytes
Redo Buffers                         14692352 bytes
Database mounted.
SQL> recover database using backup controlfile;//直接回车
ORA-00279: change 1999797 generated at 11/03/2016 10:03:03 needed for thread 1
ORA-00289: suggestion :
/home/oracle/product/10.2.0/db_1/dbs/arch1_2_926891233.dbf
ORA-00280: change 1999797 for thread 1 is in sequence #2

Specify log: {<RET>=suggested | filename | AUTO | CANCEL}
ORA-00308: cannot open archived log
'/home/oracle/product/10.2.0/db_1/dbs/arch1_2_926891233.dbf'
ORA-27037: unable to obtain file status
Linux-x86_64 Error: 2: No such file or directory
Additional information: 3

SQL> alter database open resetlogs;
System altered.
到此,已经解决了日志丢失的问题,我们还需要把隐藏参数给关掉:
SQL> show parameter "_allow_resetlogs_corruption";
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
_allow_resetlogs_corruption          boolean     TRUE
SQL>
SQL> alter system reset "_allow_resetlogs_corruption" scope=spfile sid='*';
System altered.
SQL>
重启一下数据库:
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup;
ORACLE instance started.
Total System Global Area 1375731712 bytes
Fixed Size                               2083848 bytes
Variable Size                       402654200 bytes
Database Buffers                956301312 bytes
Redo Buffers                         14692352 bytes
Database mounted.
Database opened.
SQL>
再看一下目录下的重做日志文件:
oracle@linux:~/data/oradata/zxin> ll *.log
-rw-r----- 1 oracle dba 52429312 2016-11-03 10:42 redo01.log
-rw-r----- 1 oracle dba 52429312 2016-11-03 10:42 redo02.log
-rw-r----- 1 oracle dba 52429312 2016-11-03 10:42 redo03.log
oracle@linux:~/data/oradata/zxin>



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值