ITPub博客

首页 > 数据库 > Oracle > oradebug推进SCN

oradebug推进SCN

原创 Oracle 作者:sambatuzi 时间:2020-09-11 11:14:08 0 删除 编辑
数据库版本 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;



来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31519308/viewspace-2718780/,如需转载,请注明出处,否则将追究法律责任。

下一篇: 细粒度审计 FGA
请登录后发表评论 登录
全部评论

注册时间:2018-01-30

  • 博文量
    19
  • 访问量
    14946