小编给大家分享一下oracle出现ORA-00600错误如何处理,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

由于客户现场异常断电,oracle数据库又无法启动了。远程上去看看吧。

数据库只能mount,已经无法启动

SQL>selectstatusfromv$instance;STATUS------------MOUNTEDSQL>ALTERDATABASEOPEN;ALTERDATABASEOPEN*ERRORatline1:ORA-01589:mustuseRESETLOGSorNORESETLOGSoptionfordatabaseopen

尝试recover和resetlogs open都不行

SQL>recoverdatabase;ORA-00283:recoverysessioncanceledduetoerrorsORA-01610:recoveryusingtheBACKUPCONTROLFILEoptionmustbedoneSQL>ALTERDATABASEOPENresetlogs;ALTERDATABASEOPENresetlogs*ERRORatline1:ORA-01113:file1needsmediarecoveryORA-01110:datafile1:'D:\APP\ORACLE\ORADATA\PRJDB\SYSTEM01.DBF'

Alert log 显示错误

~~~~~~~~~~~~~~~~SunJan1419:52:292018ALTERDATABASEOPENBeginningcrashrecoveryof1threadsparallelrecoverystartedwith3processes......StartedredoscanCompletedredoscanread2300KBredo,0datablocksneedrecoveryErrorsinfiled:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc(incident=315209):ORA-00600:internalerrorcode,arguments:[kcratr_nab_less_than_odr],[1],[29904],[4864],[4870],[],[],[],[],[],[],[]Incidentdetailsin:d:\app\oracle\diag\rdbms\prjdb\prjdb\incident\incdir_315209\prjdb_ora_1644_i315209.trcAbortingcrashrecoveryduetoerror600Errorsinfiled:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc:ORA-00600:internalerrorcode,arguments:[kcratr_nab_less_than_odr],[1],[29904],[4864],[4870],[],[],[],[],[],[],[]Errorsinfiled:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc:ORA-00600:internalerrorcode,arguments:[kcratr_nab_less_than_odr],[1],[29904],[4864],[4870],[],[],[],[],[],[],[]ORA-600signalledduring:ALTERDATABASEOPEN...~~~~~~~~~~~~~~~~~~~

结合ALERT里的错误ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1], [29904], [4864], [4870],是由于服务器异常断电,导致LGWR写redo log时失败,
下次重新启动数据库时,需要做实例级恢复,而又无法从联机日志文件里获取到这些redo信息,因为上次断电时,写日志失败了。

那么ORA-00600的错误里,那几个参数 [1], [29904], [4864], [4870]的含义是,实例需要恢复sequence为29904的redo文件,需要恢复到编号为4870的日志块,而实际上只能恢复到第4864个日志块儿,所以数据库就不能正常启动。

那我们怎么办呢?先检查一下控制文件和datafile记录的checkpoint_change#信息吧。

数据文件检查点(记录在控制文件中)

SQL>selectfile#,checkpoint_change#,last_change#fromv$datafilewhererownum<5;FILE#CHECKPOINT_CHANGE#LAST_CHANGE#----------------------------------------1664629049266462904936646290494664629049

系统检查点(记录在控制文件中)

SQL>selectcheckpoint_change#fromv$database;CHECKPOINT_CHANGE#----------------------------------------664607310

数据文件头检查点(记录在数据文件中)

SQL>selectfile#,checkpoint_change#fromv$datafile_headerwhererownum<5;FILE#CHECKPOINT_CHANGE#----------------------------1664629049266462904936646290494664629049

-7. 以上三个checkpoint_change#要一致(只读、脱机表空间除外),数据库才能正常打开。否则会需要进行一步的处理。正常关库时,会生成新的检查点,写入上述三个checkpoint_change#,同时数据文件中的last_change#也会记录下该检查点,也就是说三个checkpoint_change#与last_change#记录着同一个值。

-8. 通过上面的错误,以及checkpoint_change#的不一致,已经可以确认,就是控制文件,由于断电。导致的controlfile损坏(checkpoint_change#不一致)。

-9. 由于没有备份,我们只能通过重建controlfile的方式,来解决这个问题。

指定trace文件的生成路径
SQL&gt; alter database backup controlfile to trace as '/tmp/controlfile.trc';

生成文件提取建库脚本如下,启动数据库到nomount状态,执行下面脚本。
注意:类似的恢复操作,先将现有的数据库进行备份。即使这个数据库已经无法启动。我们也要防止恢复操作导致的更严重的问题。

CREATECONTROLFILEREUSEDATABASE"PRJDB"NORESETLOGSFORCELOGGINGARCHIVELOGMAXLOGFILES16MAXLOGMEMBERS3MAXDATAFILES200MAXINSTANCES8MAXLOGHISTORY584LOGFILEGROUP1'D:\APP\ORACLE\ORADATA\PRJDB\REDO01.LOG'SIZE50MBLOCKSIZE512,GROUP2'D:\APP\ORACLE\ORADATA\PRJDB\REDO02.LOG'SIZE50MBLOCKSIZE512,GROUP3'D:\APP\ORACLE\ORADATA\PRJDB\REDO03.LOG'SIZE50MBLOCKSIZE512DATAFILE'D:\APP\ORACLE\ORADATA\PRJDB\SYSTEM01.DBF','D:\APP\ORACLE\ORADATA\PRJDB\SYSAUX01.DBF','D:\APP\ORACLE\ORADATA\PRJDB\UNDOTBS01.DBF','D:\APP\ORACLE\ORADATA\PRJDB\USERS01.DBF'CHARACTERSETUS7ASCII;

-10. 检查数据库状态

SQL>selectstatusfromv$instance;STATUS------------MOUNTED

-11. 尝试重启一下,看到是需要恢复的(其实我是知道这样起不来的,但是就像任性的看看报错)。

SQL>alterdatabaseopen;alterdatabaseopen*ERRORatline1:ORA-01113:file1needsmediarecoveryORA-01110:datafile1:'D:\APP\ORACLE\ORADATA\PRJDB\SYSTEM01.DBF'

-12. 恢复数据库,其实啥也没做,recover就是走个过场,但是必须得走这个流程。

SQL>recoverdatabase;Mediarecoverycomplete.

启动数据库,成功

SQL>alterdatabaseopen;Databasealtered.SQL>selectstatusfromv$instance;STATUS-----------OPEN

再看看checkpoint_change#值,统一了吧。

SQL>selectfile#,checkpoint_change#,last_change#fromv$datafilewhererownum<5;FILE#CHECKPOINT_CHANGE#LAST_CHANGE#----------------------------------------1664649053266464905336646490534664649053

SQL>selectcheckpoint_change#fromv$database;CHECKPOINT_CHANGE#------------------664649053

SQL>selectfile#,checkpoint_change#fromv$datafile_headerwhererownum<5;FILE#CHECKPOINT_CHANGE#----------------------------1664649053266464905336646490534664649053

以上是“oracle出现ORA-00600错误如何处理”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!