ORA-00600 Kcfrbd_3 出现在查询 DBA_EXTENTS

盖国强 2019-05-08
15
0 0
摘要:如果是数据文件头部的信息记录错误,和数据文件本身不符合,则需要修改数据文件头部的文件大小信息,才能够解决该问题。

问题描述

在某些异常情况下,查询数据库的dba_extents字典表时,可能遇到ORA-600 kcfrbd_3错误,这个错误是由于文件大小和控制文件不符合导致的,触发原因可能是数据库写异常,通常可以通过重建控制文件来消除错误。

但是,如果是数据文件头部的信息记录错误,和数据文件本身不符合,则需要修改数据文件头部的文件大小信息,才能够解决该问题。


专家解答

这一问题极其少见,在MOS Note 601798.1 记录如下参考信息:

Oracle reports the ORA-00600: [kcfrbd_3] on a particular query.
The same exception is encountered if you try to select DBA_EXTENTS using a FILE#/BLOCK#.

以下是这个600错误的几个主要参数说明:

ksedmp: internal or fatal error
ORA-00600: internal error code, arguments: [kcfrbd_3], [13], [64011], [1], [64000], [64000], [], []
Arg [a] File number
Arg [b] Block number
Arg [c] Nro of blocks
Arg [d] Logical File Size
Arg [e] File Size

第一个参数是文件号,如下 13 为文件号:

SELECT segment_name , segment_type , owner , tablespace_name
FROM sys.dba_extents
WHERE file_id = 13
AND 64011 BETWEEN block_id and block_id + blocks -1;
ERROR at line 2:
ORA-00600: internal error code, arguments: [kcfrbd_3], [13], [66499], [1], [64000], [64000], [], []
Cause
There is a corruption on the extent allocation table to tablespace that 
the file# 13 belongs to.
For example, in this case,
Datafile # 13 is +DATA/ORCL/datafile/mgmt_tablespace.340.655388135
     (FOB) flags=512 fib=0x1629c8f68 incno=0 pending i/o cnt=0
    fname=+DATA/ORCL/datafile/mgmt_tablespace.340.655388135
    fno=13 lblksz=8192 fsiz=64000
We are trying to access the block 64011 that is beyond the number of blocks 6400.

最简单的情况,可以通过 resize 文件来消除。

「喜欢文章,快来给作者赞赏墨值吧」

评论

0
0
Oracle
订阅
欢迎订阅Oracle频道,订阅之后可以获取最新资讯和更新通知。
墨值排行
今日本周综合
近期活动
全部
相关课程
全部