oradebug推进SCN

来源:这里教程网 时间:2026-03-03 16:09:54 作者:
数据库版本 11.2.0.4
现象:数据库磁盘损坏,确认在线日志文件损坏,并且数据库没有备份。故只能选择使用 隐含参数 _ALLOW_RESETLOGS_CORRUPTION 强行启动数据库。
预估步骤:
1,创建pfile 向其中加入隐含参数,并利用该pfile 启动数据库到mount状态。
2,以 alter database open resetlogs 打开数据库。
实际经过:
1,创建pfile 向其中加入隐含参数,并利用该pfile 启动数据库到mount状态。
2,以 alter database open resetlogs 打开数据库。
3,数据库未启动并报错 ORA-00600: internal error code, arguments: [2662] 详情见600文档
此报错为控制文件中checkpoint_change# 记录小于 数据文件中的 checkpoint记录。
由于没有可用redo日志,无法recover 控制文件到指定scn,当前只能选择其他推进 controlfile checkpoint的方法:
(1)利用10015 推进控制文件:
alter session set events '10015 trace name adjust_scn level n';
结果:失败
失败原因:只适用11.2.0.2g之前的版本,不适用11g版本数据库
(2)利用隐含参数 _minimum_giga_scn
这个隐含直接执行了控制文件的最小scn无需推进。
结果:失败
失败原因:_minimum_giga_scn=n,提升SCN 只使用于 11.2.0.2 不适合本数据库
(3)利用oradebug 修改控制文件scn(内存修改),详情见文档:
利用oradebug 修改内存中控制文件的scn记录,但是在mount 查看v$database 中的checkpoint_change 内容仍为0。
结果:成功

SQL> oradebug setmypid
Statement processed.
SQL> oradebug dumpvar sga kcsgscn_
kcslf kcsgscn_ [06001AE70, 06001AEA0) = 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 6001AB50 00000000
SQL> select to_char('143040799499','xxxxxxxxxxx') from dual ;
  214de5630b
  
SQL>  oradebug poke 0x06001AE70 8 0x214de5630b
BEFORE: [06001AE70, 06001AE78) = 00000000 00000000
AFTER:	[06001AE70, 06001AE78) = 4DE5630B 00000021
SQL> oradebug dumpvar sga kcsgscn_
kcslf kcsgscn_ [06001AE70, 06001AEA0) = 4DE5630B 00000021 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 6001AB50 00000000
SQL> alter database open resetlogs;
SQL> select current_scn from v$database ;
143040800363

计算好需要推进SCN的值 ORA-00600: internal error code, arguments: [2662], [2], [1424152334], [2], [1424164624], [8388617], [], [] select 2*power(2,32)+1424164624 from dual; 10014099216 ORA-00600: internal error code, arguments: [2662], [0], [5685940], [0], [5685970], [4194432], [], [], [], [], [], [] select 2*power(2,32)+ 5685970 from dual; 8595620562 总结公式:c * power(2,32) + d [可适当加一点] c代表:Arg [c] dependent SCN WRAP d代表:Arg [d] dependent SCN BASE oradebug setmypid oradebug dumpvar sga kcsgscn_ oradebug poke 0x060012658 8 10014099216 oradebug dumpvar sga kcsgscn_ alter database open resetlogs;

相关推荐