数据恢复:隐含参数_minimum_giga_scn被废弃后如何调SCN

崔华,网名 dbsnake

Oracle ACE Director,ACOUG 核心专家

在很多数据恢复的场景中,我们可能需要调节SCN,但是一个重要的隐含参数_minimum_giga_scn,在Oracle 11.2.0.2打上相关的SCN的补丁以及后续的版本中已经被废弃。

Connected to Oracle Database 12c Enterprise Edition Release 12.1.0.1.0

Connected as SYS

SQL> select count(*) from sys.all_parameters where name like ‘_minimum_giga_scn%’;

COUNT(*)

———-

0

SQL> select dbms_flashback.get_system_change_number()/(1024*1024*1024) from dual;

DBMS_FLASHBACK.GET_SYSTEM_CHAN

——————————

0.00187269318848848

[oracle@localhost dbs]$ cat initdb121.ora

db121.__data_transfer_cache_size=0

db121.__db_cache_size=251658240

……省略显示部分内容

*.undo_tablespace=’UNDOTBS1′

*._minimum_giga_scn=1

SQL> startup pfile=/u01/app/oracle/product/12.1.0/dbhome_1/dbs/initdb121.ora

LRM-00101: unknown parameter name ‘_minimum_giga_scn’

ORA-01078: failure in processing system parameters

另外,经我测试,不仅_minimum_giga_scn失效了,alter session set events ‘10015 trace name adjust_scn level XXX’也失效了。

我没有采用改数据文件头再重建控制文件的方法,因为在ASM的环境下这种方法太麻烦了(除非是以后ODU内嵌的BBED支持批量修改文件头)。

我采用的是把控制文件拷出来直接修改控制文件的方式,幸运的是,12cR1的控制文件中我想改的地方其offset和之前的版本比并未改变。

这里我想把SCN调整为1G。

修改方法为:

1、当数据块为8k的时候,控制文件大小为16k

2、找到Controlfile Checkpointed at scn,偏移量为第一个块的60,比如0x4060,然后具体位置在0x4060的第9至第14个byte

3、找到第一个块的第一行,如0x4000,将offset为15的flag由0x04改为0x00,并同时将checksum值(offset为16、17)全部清零。

如下是改完控制文件后的效果:

SQL> startup mount pfile=/u01/app/oracle/product/12.1.0/dbhome_1/dbs/initdb121.ora

ORACLE instance started.

Total System Global Area 438423552 bytes

Fixed Size 2289304 bytes

Variable Size 255852904 bytes

Database Buffers 176160768 bytes

Redo Buffers 4120576 bytes

Database mounted.

SQL> alter database open;

Database altered.

SQL> select dbms_flashback.get_system_change_number()/(1024*1024*1024) from dual;

DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER()/(1024*1024*1024)

———————————————————-

1.00001949

这里再补充另外一种方法,即通过oradebug修改kcsgscn_的方式也可以达到同样的效果:

如下是Big Endian平台kcsgscn_的显示效果:

SQL> select to_char(dbms_flashback.get_system_change_number(),’XXXXXXXXXXXX’) from dual;

TO_CHAR(DBMS_FLASHBACK.GET_SYS

——————————

94393E2E03F

从上述显示结果中我们可以看到,上述系统的SCN wrap为0x0943,SCN base为0x93E2E03F,这个显示结果和如下用oradebug查看kcsgscn_的显示结果一致:

SQL> oradebug setmypid

Statement processed.

SQL> oradebug dumpvar sga kcsgscn_

kcslf kcsgscn_ [7000000000182A0, 7000000000182D0) = 00000943 93E2E077 00000000 00000000 005C3BEE 00000000 00000000 00000000 00000000 00000000 07000000 00017F80

kcsgscn_就是SCN的值,所以其值会不断往上增长:

SQL> oradebug dumpvar sga kcsgscn_

kcslf kcsgscn_ [7000000000182A0, 7000000000182D0) = 00000943 93E2E0A3 00000000 00000000 005C3C08 00000000 00000000 00000000 00000000 00000000 07000000 00017F80

oradebug中可以用poke命令来修改内存,其语法为:

“oradebug poke <address> <length> <value>” allows you to modify a given region of memory (length of memory is limited to size of scalar C types)

还是回到之前那个例子,之前我们已经通过修改控制文件的方式把SCN调成了1G,现在我们通过oradebug直接修改内存的方式把SCN从1G调整到2G。

现在系统SCN为1G:

SQL> select dbms_flashback.get_system_change_number()/(1024*1024*1024) from dual;

DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER()/(1024*1024*1024)

———————————————————-

1.00007167

SQL> select CHECKPOINT_CHANGE#/(1024*1024*1024) from v$database;

CHECKPOINT_CHANGE#/(1024*1024*1024)

———————————–

1.00007022

SQL> select to_char(CHECKPOINT_CHANGE#,’XXXXXXXXXXXX’) from v$database;

TO_CHAR(CHECK

————-

40012688

现在数据库服务器为Linux,是Little Endian,所以其SCN base在前,SCN wrap在后,这和如下oradebug的显示结果一致:

SQL> oradebug setmypid

Statement processed.

SQL> oradebug dumpvar sga kcsgscn_

kcslf kcsgscn_ [06001AD30, 06001AD60) = 40012D2C 00000000 00000000 00000000 00000232 00000000 00000000 00000000 00000000 00000000 6001A8D0 00000000

2G对应的16进制是0x80000000

SQL> select to_char(2*1024*1024*1024,’XXXXXXXXXXXX’) from dual;

TO_CHAR(2*1024*1024*1024,’XXXX

——————————

80000000

SQL> shutdown immediate

Database closed.

Database dismounted.

ORACLE instance shut down.

SQL> startup mount

ORACLE instance started.

Total System Global Area 438423552 bytes

Fixed Size 2289304 bytes

Variable Size 255852904 bytes

Database Buffers 176160768 bytes

Redo Buffers 4120576 bytes

Database mounted.

SQL> oradebug setmypid

Statement processed.

SQL> oradebug dumpvar sga kcsgscn_

kcslf kcsgscn_ [06001AD30, 06001AD60) = 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 6001A8D0 00000000

SQL> oradebug poke 0x06001AD30 4 0x80000000

BEFORE: [06001AD30, 06001AD34) = 00000000

AFTER: [06001AD30, 06001AD34) = 80000000

SQL> oradebug dumpvar sga kcsgscn_

kcslf kcsgscn_ [06001AD30, 06001AD60) = 80000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 6001A8D0 00000000

SQL> alter database open;

Database altered.

SQL> select dbms_flashback.get_system_change_number()/(1024*1024*1024) from dual;

DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER()/(1024*1024*1024)

———————————————————-

2.00000081

从上述显示结果中我们可以看到,我们已经成功的把系统SCN从1G调到了2G。

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2016-05-25

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏乐沙弥的世界

启用用户进程跟踪

仅仅需要标识该会话并为该会话启用跟踪(专用模式为一对一模式,即一个用户进程对应一个服务器进程)

802
来自专栏杨建荣的学习笔记

dataguard switchover的自动化脚本实现 (r5笔记第48天)

data guard的主要功能就是作为备库来同步主库的数据变化,一般使用中物理standby使用的比较多。data guard显示威力的一个场景就是switho...

3495
来自专栏乐沙弥的世界

使用crs_profile管理RAC资源配置文件

    profile通常指配置文件,crs_profile望文生义可知,就是管理集群的配置文件。在Oraclele RAC中,所有的CRS资源存放在OCR磁盘...

673
来自专栏乐沙弥的世界

Oracle 基于用户管理恢复的处理

Oracle支持多种方式来管理数据文件的备份与恢复来保证数据库的可靠与完整。除了使用RMAN工具以及第三方备份与恢复工具之外,基于

492
来自专栏乐沙弥的世界

收缩临时表空间

        当排序操作、重建索引等大型操作无法在内存中完成时,临时表空间将为排序提供便利。一般情况下临时表空间为多个用户,多个会话所共 享。不能为会话分...

1013
来自专栏杨建荣的学习笔记

关于Oracle重启数据库的一个bug(r5笔记第50天)

关于drop database在oracle中是致命的操作,这个操作自己在测试环境中体验过,会完全删除数据文件,因此这个操作非常敏感但是实用性不强,不过话说过来...

3474
来自专栏杨建荣的学习笔记

Oracle 12c升级检查问题分析(r10笔记第69天)

今天计划把一个测试环境升级到12c,为了练练手,先在备库上来做。数据库版本是11.2.0.3.0,计划升级到12.1.0.2.0。 为了不影响原有的测试主库,我...

3778
来自专栏乐沙弥的世界

中小型数据库 RMAN CATALOG 备份恢复方案(三)

      在前两篇文章中描述了中小型数据库使用RMAN catalog设计备份与恢复方案,并给出了所有相关的脚本来从某种车程度上模拟Oracle Data G...

661
来自专栏沃趣科技

复制状态与变量记录表 | performance_schema全方位介绍

不知不觉中,performance_schema系列快要接近尾声了,今天将带领大家一起踏上系列第六篇的征程(全系共7个篇章),在这一期里,我们将为大家全面讲解p...

1603
来自专栏乐沙弥的世界

SYSTEM 表空间管理及备份恢复

SYSTEM表空间是Oracle数据库最重要的一个表空间,存放了一些DDL语言产生的信息以及PL/SQL包、视图、函数、过程等,称之为数据字典,

702

扫码关注云+社区