同事前一阵子搬着台式机出去演示,回来时候,特豪迈地拔电源,装车走人;回来后悲催地发现数据库普通用户登录失败,数据库首先出现ORA-01033:ORACLE initialization or shutdown;然后按照网上指导
在DOS环境下
sqlplus /NOLOG
SQL>connect sys/sys as sysdba
SQL>shutdown normal
SQL>startup mount
SQL>alter database open;
然后 ,数据库服务器出现ORA-00600[kcratr_nab_less_than_odr],不能open数据库
ORA-00600: 内部错误代码, 参数: [kcratr_nab_less_than_odr], [1], [1984], [219……
遇到的错误是上面红色部分,不完整,当时没记录,后面的数字好像没什么特殊,按照下面步骤做,一样能完成open。
1.open数据库报ORA-00600[kcratr_nab_less_than_odr]
SQL> ALTER DATABASE OPEN;
ALTER DATABASE OPEN
*
第 1 行出现错误:
ORA-00600: 内部错误代码, 参数: [kcratr_nab_less_than_odr], [1], [99189],
[43531], [43569], [], [], [], [], [], [], []
2.查看alert日志
Wed Jan 11 13:56:16 2012
ALTER DATABASE OPEN
Beginning crash recovery of 1 threads
parallel recovery started with 2 processes
Started redo scan
Completed redo scan
read 54591 KB redo, 0 data blocks need recovery
Errors in file d:\dbdms\diag\rdbms\dbdms\dbdms\trace\dbdms_ora_3108.trc (incident=818557):
ORA-00600: 内部错误代码, 参数: [kcratr_nab_less_than_odr], [1], [99189], [43531], [43569], [], [], [], [], [], [], []
Incident details in: d:\dbdms\diag\rdbms\dbdms\dbdms\incident\incdir_818557\dbdms_ora_3936_i818557.trc
Aborting crash recovery due to error 600
Errors in file d:\dbdms\diag\rdbms\dbdms\dbdms\trace\dbdms_ora_3108.trc:
ORA-00600: 内部错误代码, 参数: [kcratr_nab_less_than_odr], [1], [99189], [43531], [43569], [], [], [], [], [], [], []
Errors in file d:\dbdms\diag\rdbms\dbdms\dbdms\trace\dbdms_ora_3108.trc:
ORA-00600: 内部错误代码, 参数: [kcratr_nab_less_than_odr], [1], [99189], [43531], [43569], [], [], [], [], [], [], []
ORA-600 signalled during: ALTER DATABASE OPEN...
Trace dumping is performing id=[cdmp_20120110214555]
3.查看trace文件
Trace file d:\dbdms\diag\rdbms\dbdms\dbdms\trace\dbdms_ora_3108.trc
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
Windows NT Version V6.1 Service Pack 1
CPU : 2 - type 8664, 2 Physical Cores
Process Affinity : 0x0x0000000000000000
Memory (Avail/Total): Ph:2250M/4060M, Ph+PgF:5868M/8119M
Instance name: dbdms
Redo thread mounted by this instance: 1
Oracle process number: 17
Windows thread id: 3108, image: ORACLE.EXE (SHAD)
…………………………
WARNING! Crash recovery of thread 1 seq 99189 is
ending at redo block 43531 but should not have ended before
redo block 43569
Incident 826550 created, dump file: d:\dbdms\diag\rdbms\dbdms\dbdms\incident\incdir_826550\dbdms_ora_3108_i826550.trc
ORA-00600: ??????, ??: [kcratr_nab_less_than_odr], [1], [99189], [43531], [43569], [], [], [], [], [], [], []
ORA-00600: ??????, ??: [kcratr_nab_less_than_odr], [1], [99189], [43531], [43569], [], [], [], [], [], [], []
ORA-00600: ??????, ??: [kcratr_nab_less_than_odr], [1], [99189], [43531], [43569], [], [], [], [], [], [], []
通过alert和trace中的内容可以知道,数据库需要恢复到rba到43569,但是因为某种原因实例恢复的时候,只能利用1 thread 99189 seq#,恢复rba到43531。从而导致数据库无法正常open
This Problem is caused by Storage Problem of the Database Files.
The Subsystem (eg. SAN) crashed while the Database was open.
The Database then crashed since the Database Files were not accessible anymore.
This caused a lost Write into the Online RedoLogs and so Instance Recovery is not possible and raising the ORA
4.解决方法
- SQL> SELECT STATUS FROM V$INSTANCE;
-
- STATUS
-
- MOUNTED
-
-
- SQL> RECOVER DATABASE ;
- ORA-00283: 恢复会话因错误而取消
- ORA-00264: 不要求恢复
-
-
-
- SQL> ALTER DATABASE OPEN;
- ALTER DATABASE OPEN
- *
- 第 1 行出现错误:
- ORA-00600: 内部错误代码, 参数: [kcratr_nab_less_than_odr], [1], [99189],
- [43531], [43569], [], [], [], [], [], [], []
-
-
- SQL> RECOVER DATABASE UNTIL CANCEL;
- ORA-10879: error signaled in parallel recovery slave
- ORA-01547: 警告: RECOVER 成功但 OPEN RESETLOGS 将出现如下错误
- ORA-01152: 文件 1 没有从过旧的备份中还原
- ORA-01110: 数据文件 1: 'C:\app\Administrator\oradata\pdip\SYSTEM01.DBF'
-
-
- SQL> ALTER DATABASE BACKUP CONTROLFILE TO TRACE AS 'C:\app\Administrator\oradata\pdip\1.TXT';
-
- 数据库已更改。
-
- SQL> SHUTDOWN IMMEDIATE;
- ORA-01109: 数据库未打开
-
-
- 已经卸载数据库。
- ORACLE 例程已经关闭。
- SQL> STARTUP NOMOUNT;
- ORACLE 例程已经启动。
-
- Total System Global Area 417546240 bytes
- Fixed Size 2176328 bytes
- Variable Size 268438200 bytes
- Database Buffers 138412032 bytes
- Redo Buffers 8519680 bytes
- SQL> CREATE CONTROLFILE REUSE DATABASE "PDIP" NORESETLOGS NOARCHIVELOG
MAXLOGFILES 16
MAXLOGMEMBERS 3
MAXDATAFILES 100
MAXINSTANCES 8
MAXLOGHISTORY 18688
LOGFILE
GROUP 1 'C:\app\Administrator\oradata\pdip\REDO01.LOG' SIZE 50M BLOCKSIZE 512,
GROUP 2 'C:\app\Administrator\oradata\pdip\REDO02.LOG' SIZE 50M BLOCKSIZE 512,
GROUP 3 'C:\app\Administrator\oradata\pdip\REDO03.LOG' SIZE 50M BLOCKSIZE 512
DATAFILE
'C:\APP\ADMINISTRATOR\ORADATA\PDIP\SYSTEM01.DBF',
'C:\APP\ADMINISTRATOR\ORADATA\PDIP\SYSAUX01.DBF',
'C:\APP\ADMINISTRATOR\ORADATA\PDIP\EXAMPLE01.DBF',
'C:\APP\ADMINISTRATOR\ORADATA\PDIP\JASFRAMEWORK.DBF',
'C:\APP\ADMINISTRATOR\ORADATA\PDIP\SDE.DBF',
'C:\APP\ADMINISTRATOR\ORADATA\PDIP\UNDOTBS01.DBF',
'C:\APP\ADMINISTRATOR\ORADATA\PDIP\USERS01.DBF'
CHARACTER SET ZHS16GBK;
- 注意上面log和DBF文件是安装数据库实例的文件夹,保证上面文件存在,temp01.DBF文件除外。
- 控制文件已创建。
-
- SQL> RECOVER DATABASE ;
- 完成介质恢复。
- SQL> ALTER DATABASE OPEN;
-
- 数据库已更改。
-
在这次恢复中,主要就是重建控制文件,然后直接恢复成功,如果redo有损坏,那么可能需要使用不完全恢复,然后使用resetlogs打开数据库
参考http://www.xifenfei.com/2012/01/ora-00600kcratr_nab_less_than_odr%e6%95%85%e9%9a%9c%e8%a7%a3%e5%86%b3.html