当前联机日志损坏恢复_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1645 | 回复: 0   主题: 当前联机日志损坏恢复        下一篇 
多多练腹肌
注册用户
等级:新兵
经验:72
发帖:1
精华:0
注册:2015-7-7
状态:离线
发送短消息息给多多练腹肌 加好友    发送短消息息给多多练腹肌 发消息
发表于: IP:您无权察看 2015-11-20 17:22:39 | [全部帖] [楼主帖] 楼主

环境模拟
删除状态为active的联机日志,然后强行关闭数据库


处理过程

SQL> startupORACLE instance started.
Total System Global Area 167772160 bytesFixed Size 1260720 bytesVariable Size 142607184 bytesDatabase Buffers 16777216 bytesRedo Buffers 7127040 bytesDatabase mounted.ORA-00313: open failed for members of log group 1 of thread 1ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’ORA-27037: unable to obtain file statusLinux Error: 2: No such file or directoryAdditional information: 3

Alert.log 日志中错误

Wed Aug 24 00:26:33 2011Errors in file /u01/admin/xienfei/udump/xff_ora_9186.trc:ORA-00313: open failed for members of log group 1 of thread 1ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’ORA-27037: unable to obtain file statusLinux Error: 2: No such file or directoryAdditional information: 3
xff_ora_9186.trc文件中错误ORA-00313: open failed for members of log group 1 of thread 1ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’ORA-27037: unable to obtain file statusLinux Error: 2: No such file or directoryAdditional information: 3

查询当前日志组状态

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;
GROUP# STATUS MEMBER———- —————- ———————————————1 CURRENT /u01/oradata/xienfei/redo01.log3 INACTIVE /u01/oradata/xienfei/redo03.log2 ACTIVE /u01/oradata/xienfei/redo02.log

尝试删除redo日志

SQL> alter database drop logfile group 1;
alter database drop logfile group 1
*
ERROR at line 1:
ORA-01623: log 1 is current log for instance xff (thread 1) – cannot drop
ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’

发现是当前日志不能被删除,尝试切换日志

SQL> alter system switch logfile;alter system switch logfile*ERROR at line 1:ORA-01109: database not open
在数据库未打开状态,不能切换日志,只能尝试清空日志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 instance xff (thread 1)ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’

因为数据库恢复需要使用,不能被清空,尝试不完成恢复

SQL> recover database until cancel;ORA-00279: change 1272687 generated at 08/24/2011 00:20:05 needed for thread 1ORA-00289: suggestion : /u01/archive/1_27_756841839.arcORA-00280: change 1272687 for thread 1 is in sequence #27
Specify log: {=suggested | filename | AUTO | CANCEL}autoORA-00279: change 1272903 generated at 08/24/2011 00:25:17 needed for thread 1ORA-00289: suggestion : /u01/archive/1_28_756841839.arcORA-00280: change 1272903 for thread 1 is in sequence #28ORA-00278: log file ‘/u01/archive/1_27_756841839.arc’ no longer needed for thisrecovery
ORA-00308: cannot open archived log ‘/u01/archive/1_28_756841839.arc’ORA-27037: unable to obtain file statusLinux Error: 2: No such file or directoryAdditional information: 3
ORA-01547: warning: RECOVER succeeded but OPEN RESETLOGS would get error belowORA-01194: file 1 needs more recovery to be consistentORA-01110: data file 1: ‘/u01/oradata/xienfei/system01.dbf’

已经提示数据不一致,尝试着打开数据库

SQL> alter database open resetlogs;
alter database open resetlogs
*
ERROR at line 1:
ORA-01194: file 1 needs more recovery to be consistent
ORA-01110: data file 1: ‘/u01/oradata/xienfei/system01.dbf’

创建pfile文件,添加隐含参数,使之不进行检查点一致性校验

SQL> create pfile=’/tmp/pfile’ from spfile;
File created.

修改pfile ,添加以下参数

*._allow_resetlogs_corruption=TRUE*._allow_error_simulation=TRUE
SQL> shutdown abortORACLE instance shut down.

使用pfile打开数据库

SQL> startup pfile=’/tmp/pfile’ORACLE instance started.
Total System Global Area 167772160 bytesFixed Size 1260720 bytesVariable Size 150995792 bytesDatabase Buffers 8388608 bytesRedo Buffers 7127040 bytesDatabase mounted.ORA-38760: This database instance failed to turn on flashback database

发现flashback导致数据库不能被正常打开,尝试关闭它

SQL> alter database flashback off;
Database altered.

尝试直接open数据库

SQL> alter database open;
alter database open
*
ERROR at line 1:
ORA-01589: must use RESETLOGS or NORESETLOGS option for database open

根据提示,使用resetlogs打开数据库

SQL> alter database open resetlogs;
Database altered.

查询日志状态

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;
GROUP# STATUS MEMBER———- —————- ———————————————3 UNUSED /u01/oradata/xienfei/redo03.log2 UNUSED /u01/oradata/xienfei/redo02.log1 CURRENT /u01/oradata/xienfei/redo01.log

因为group1错误,而当前日志组在group 1上,所以切换日志组

SQL> alter system switch logfile;
System altered.
SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;
GROUP# STATUS MEMBER———- —————- ———————————————3 UNUSED /u01/oradata/xienfei/redo03.log2 CURRENT /u01/oradata/xienfei/redo02.log1 ACTIVE /u01/oradata/xienfei/redo01.log
SQL> alter system checkpoint;
System altered.
SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;
GROUP# STATUS MEMBER———- —————- ———————————————3 UNUSED /u01/oradata/xienfei/redo03.log2 CURRENT /u01/oradata/xienfei/redo02.log1 INACTIVE /u01/oradata/xienfei/redo01.log删除有问题的group 1日志组SQL> alter database drop logfile group 1;
Database altered.
SQL> alter system switch logfile;
System altered.

添加日志组并检查是否正确

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;
GROUP# STATUS MEMBER———- —————- ———————————————3 CURRENT /u01/oradata/xienfei/redo03.log2 ACTIVE /u01/oradata/xienfei/redo02.log
SQL> alter database add logfile group 1 ‘/u01/oradata/xienfei/redo01.log’ size 50m reuse;
Database altered.
SQL> alter system switch logfile;
System altered.
SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;
GROUP# STATUS MEMBER———- —————- ———————————————3 ACTIVE /u01/oradata/xienfei/redo03.log2 ACTIVE /u01/oradata/xienfei/redo02.log1 CURRENT /u01/oradata/xienfei/redo01.log


注意:根据oracle官方建议,使用oracle隐含参数运行数据库可能存在很多不稳定因素,建议立即导出数据库数据,然后新建库,重新导入数据




                                                                                                                         --转自



赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论