ORA-00600 kcratr_nab_less_than_odr 处理小计
今天由于客户现场异常断电,oracle数据库又无法启动了。远程上去看看吧。
-
数据库只能mount,已经无法启动
SQL> select status from v$instance; STATUS ------------ MOUNTED SQL> ALTER DATABASE OPEN; ALTER DATABASE OPEN * ERROR at line 1: ORA-01589: must use RESETLOGS or NORESETLOGS option for database open
-
尝试recover和resetlogs open都不行
SQL> recover database; ORA-00283: recovery session canceled due to errors ORA-01610: recovery using the BACKUP CONTROLFILE option must be done SQL> ALTER DATABASE OPEN resetlogs; ALTER DATABASE OPEN resetlogs * ERROR at line 1: ORA-01113: file 1 needs media recovery ORA-01110: data file 1: 'D:\APP\ORACLE\ORADATA\PRJDB\SYSTEM01.DBF'
-
Alert log 显示错误
~~~~~~~~~~~~~~~~ Sun Jan 14 19:52:29 2018 ALTER DATABASE OPEN Beginning crash recovery of 1 threads parallel recovery started with 3 processes ...... Started redo scan Completed redo scan read 2300 KB redo, 0 data blocks need recovery Errors in file d:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc (incident=315209): ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1], [29904], [4864], [4870], [], [], [], [], [], [], [] Incident details in: d:\app\oracle\diag\rdbms\prjdb\prjdb\incident\incdir_315209\prjdb_ora_1644_i315209.trc Aborting crash recovery due to error 600 Errors in file d:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc: ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1], [29904], [4864], [4870], [], [], [], [], [], [], [] Errors in file d:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc: ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1], [29904], [4864], [4870], [], [], [], [], [], [], [] ORA-600 signalled during: ALTER DATABASE OPEN... ~~~~~~~~~~~~~~~~~~~
-
结合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> select file#,checkpoint_change#,last_change# from v$datafile where rownum<5; FILE# CHECKPOINT_CHANGE# LAST_CHANGE# ---------- ------------------ ------------ 1 664629049 2 664629049 3 664629049 4 664629049
系统检查点(记录在控制文件中)
SQL> select checkpoint_change# from v$database; CHECKPOINT_CHANGE# ---------- ------------------ ------------ 664607310
数据文件头检查点(记录在数据文件中)
SQL> select file#,checkpoint_change# from v$datafile_header where rownum<5; FILE# CHECKPOINT_CHANGE# ---------- ------------------ 1 664629049 2 664629049 3 664629049 4 664629049
-7. 以上三个checkpoint_change#要一致(只读、脱机表空间除外),数据库才能正常打开。否则会需要进行一步的处理。正常关库时,会生成新的检查点,写入上述三个checkpoint_change#,同时数据文件中的last_change#也会记录下该检查点,也就是说三个checkpoint_change#与last_change#记录着同一个值。
-8. 通过上面的错误,以及checkpoint_change#的不一致,已经可以确认,就是控制文件,由于断电。导致的controlfile损坏(checkpoint_change#不一致)。
-9. 由于没有备份,我们只能通过重建controlfile的方式,来解决这个问题。
指定trace文件的生成路径SQL> alter database backup controlfile to trace as '/tmp/controlfile.trc';
生成文件提取建库脚本如下,启动数据库到nomount状态,执行下面脚本。
注意:类似的恢复操作,先将现有的数据库进行备份。即使这个数据库已经无法启动。我们也要防止恢复操作导致的更严重的问题。
CREATE CONTROLFILE REUSE DATABASE "PRJDB" NORESETLOGS FORCE LOGGING ARCHIVELOG MAXLOGFILES 16 MAXLOGMEMBERS 3 MAXDATAFILES 200 MAXINSTANCES 8 MAXLOGHISTORY 584 LOGFILE GROUP 1 'D:\APP\ORACLE\ORADATA\PRJDB\REDO01.LOG' SIZE 50M BLOCKSIZE 512, GROUP 2 'D:\APP\ORACLE\ORADATA\PRJDB\REDO02.LOG' SIZE 50M BLOCKSIZE 512, GROUP 3 'D:\APP\ORACLE\ORADATA\PRJDB\REDO03.LOG' SIZE 50M BLOCKSIZE 512 DATAFILE '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' CHARACTER SET US7ASCII;
-10. 检查数据库状态
SQL> select status from v$instance; STATUS ------ ----- - MOUNTED
-11. 尝试重启一下,看到是需要恢复的(其实我是知道这样起不来的,但是就像任性的看看报错)。
SQL> alter database open; alter database open * ERROR at line 1: ORA-01113: file 1 needs media recovery ORA-01110: data file 1: 'D:\APP\ORACLE\ORADATA\PRJDB\SYSTEM01.DBF'
-12. 恢复数据库,其实啥也没做,recover就是走个过场,但是必须得走这个流程。
SQL> recover database; Media recovery complete.
-
启动数据库,成功
SQL> alter database open; Database altered. SQL> select status from v$instance; STATUS --- -------- OPEN
- 再看看checkpoint_change#值,统一了吧。
SQL> select file#,checkpoint_change#,last_change# from v$datafile where rownum<5; FILE# CHECKPOINT_CHANGE# LAST_CHANGE# ---------- ------------------ ------------ 1 664649053 2 664649053 3 664649053 4 664649053
SQL> select checkpoint_change# from v$database; CHECKPOINT_CHANGE# ------------------ 664649053
SQL> select file#,checkpoint_change# from v$datafile_header where rownum<5; FILE# CHECKPOINT_CHANGE# ---------- ------------------ 1 664649053 2 664649053 3 664649053 4 664649053
最后,再唠叨一下,备份真的很重要!很简单!
没有备份的数据库,不单单是裸奔那么简单!
不出问题,丢人!出问题,伤身啊!!
如何重建控制文件,请参考:
https://blog.51cto.com/hsbxxl/908251

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
一键打造你的Doker矿机
从什么时候开始流行CPU挖矿了?记得以前不都是用GPU吗?原来现在虚拟币的种类已经这么多了!大概研究了一下,目前CPU算力有优势的有这么几种虚拟币,貌似还都是匿名币 ZEC(零币)算法 Equihash 目前市场价格4000+ XMR(门罗币) 算法CryptoNight 目前价格4000+ BCN(字节币?) 算法CryptNote 目前价格 几分... 近期公司有几台机器被种了挖矿***,清除之余研究了一下有关CPU挖矿的工具,发现了 xmr-stak-cpu 这个东西 上网搜了搜,找到了GITHUB上的主页,好像刚升级不久 https://github.com/fireice-uk/xmr-stak 还有个早先点的版本地址为:https://github.com/fireice-uk/xmr-stak-cpu 找了一台测试机安装一下试试: #gitclonehttps://github.com/fireice-uk/xmr-stak #cdxmr-stak/ #ls CICMakeLists.txtCONTRIBUTING.mddocDockerfileLICENSEREADME...
- 下一篇
细说智能指针
提到指针,我们就会想到指针的高效,当然,滥用指针也会为我们带来许多的潜在bug。提到指针,我们就会想到内存泄漏。比如,使用指针后忘记释放,久而久之,堆空间就会全部使用完,那么会带来很大的危害。再比如,两个指针指向同一片内存区域,我们对同一片区域进行了多次释放,同样会造成内存泄漏。为了方便大家的理解,我们先来模拟一下,使用指针却忘记释放带来的危害。首先,我们要定义一个类。这次,还是定义女朋友类吧(之前写过一篇《细说C++的友元》用的就是女朋友类,这次还用这个吧,方便说明问题,更何况我们这群码畜怎么会有女朋友呢,没有女朋友只能自己创建了,哈哈哈哈)。女生都喜欢自拍,尤其是漂亮的女生。所以,女生会有很多照片,对吧。那么,我们创建的这个女朋友类,就让她有照片吧。当然了,你女朋友的照片肯定不会随便给别人的吧,所以要把picutre这个变量声明为private类型。既然,女生喜欢自拍,并且发朋友圈,也就是说,其他人虽然得不到她的照片,却可以通过她的朋友圈看到她的自拍,也就意味着我们可以通过一个public函数访问picture这个变量。那么,我们现在来写代码。 class Girlfriend{ ...
相关文章
文章评论
共有0条评论来说两句吧...