Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2882507
  • 博文数量: 200
  • 博客积分: 2413
  • 博客等级: 大尉
  • 技术积分: 3067
  • 用 户 组: 普通用户
  • 注册时间: 2011-04-01 22:07
文章分类

全部博文(200)

文章存档

2018年(2)

2017年(8)

2016年(35)

2015年(14)

2014年(20)

2013年(24)

2012年(53)

2011年(44)

分类: Oracle

2016-12-27 16:51:08

朋友遇到Oracle数据库的 REDO LOG “写丢失”,造成数据库,且无法启动。

日志如下:redo log 5无法归档,并且侦测到“写丢失”。最终导致Oracle宕机。
Errors in file /u01/app/oracle/diag/rdbmsdbcontrol/GZDBCONTROL/trace/GZDBCONTROL_ora_32198.trc:
ORA-16038: log 5 sequence# 23 cannot be archived
ORA-00742: Log read detects lost write in thread %d sequence %d block %d
ORA-00312: online log 5 thread 1: '/u01/app/oracle/fast_recovery_area/GZDBCONTROL/onlinelog/o1_mf_5_d61ctj3y_.log'
USER (ospid: 32198): terminating the instance due to error 16038
System state dump requested by (instance=1, osid=32198), summary=[abnormal instance termination].
System State dumped to trace file /u01/app/oracle/diag/rdbmsdbcontrol/GZDBCONTROL/trace/GZDBCONTROL_diag_32167_20161227110109.trc
Dumping diagnostic data in directory=[cdmp_20161227110109], requested by (instance=1, osid=32198), summary=[abnormal instance termination].

问题原因:
这三种清空都可能导致“写丢失”发生:操作系统、存储系统、Oracle内部错误。

解决办法:
使用dump判断是否真正发生了“写丢失”。
SQL> alter system dump logfile  '/u01/app/oracle/fast_recovery_area/GZDBCONTROL/onlinelog/o1_mf_5_d61ctj3y_.log' validate;

ERROR at line 1:
ORA-00742: Log read detects lost write in thread %d sequence %d block %d
ORA-00334: archived log:
'/u01/app/oracle/fast_recovery_area/GZDBCONTROL/onlinelog/o1_mf_5_d61ctj3y_.log'

从上面dump的结果确认发生了“写丢失”清空,清空问题redo logfile使其恢复正常归档。

SQL> alter database clear unarchived logfile group 5;

按照以上步骤,朋友的Oracle数据库正常启动。
最后,不要忘记做一次全备份。

参考:
Database Crashe with ORA-16038/ORA-742 Errors (文档 ID 2064718.1)


转载请注明:
十字螺丝钉
QQ:463725310
 (有更多更新的内容,欢迎访问)
http://blog.chinaunix.net/uid/23284114.html

E-MAIL:houora#gmail.com(#请自行替换为@)

阅读(11406) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~