oracle 成长历程-第二章:实例的组成-内存及进程组件概述 -SCN-1

2.3      SCN

一个贯穿数据库全局的概念----系统改变号SCN(System Change Number)

系统改变号,一个由系统内部维护的序列号。当系统需要更新的时候自动增加,它是系统中维持数据的一致性和顺序恢复的重要标志。

SCN是顺序递增的一个数字,在Oracle 中用来标识数据库的每一次改动,及其先后顺序。SCN的最大值是0xffff.ffffffff

2.3.1   OracleSCN的管理

在单节点的Instance中, SCN值存在SGA区,由system commit number latch保护。任何进程要得到当前的SCN值,都要先得到这个latch

RAC/OPS环境中,Oracle通过排队机制(Enqueue)实现SCN在各并行节点之间的顺序增长。具体有两种方法:

Ø  Lamport算法:又称面包房算法,先来先服务算法。跟很多银行采用的排队机制一样。客户到了银行,先领取一个服务号。一旦某个窗口出现空闲,拥有最小服务号的客户就可以去空闲窗口办理业务。

Ø  Commit广播算法:一有commit完成,最新的SCN就广播到所有节点中。

上述两种算法可以通过调整初始化参数max_commit_propagation_delay来切换。在多数系统 (除了Compaq Tur64 Unix)中,该参数的默认值都是700厘秒(centisecond),采用Lamport算法。如果该值小于100厘秒,Oracle就采用广播算法,并且记录在alert.log文件中。

2.3.2   几种重要的SCN

Commit SCN

当用户提交commit命令后,系统将当前SCN赋给该transaction。这些信息都反映在redo buffer中,并马上更新到redo log 文件里。

Offline SCN

除了System tablespace以外的任何表空间,当我们执行SQL>alter tablespace … offline normal命令时,就会触发一个checkpoint,将内存中的dirty buffer写入磁盘文件中。Checkpoint完成后,数据文件头会更新checkpoint SCNoffline normal SCN值。其中数据库文件头的checkpoint SCN值可通过查询列x$kccfe.fecps得到。

如果执行SQL>alter tablespace …offline命令时采用temporary immediate选项,而不用normal选项时,offline normal SCN会被设成0。这样当数据库重启后通过resetlog方式打开时,该表空间就无法再改回在线状态。

Checkpoint SCN

当数据库内存的脏数据块(dirty blocks)写到各数据文件中时,就发生一次checkpoint。数据库的当前checkpoint SCN值存在x$kccdi.diSCN中。Checkpoint SCN在数据库恢复中起着至关重要的作用。无论你用何种办法恢复数据库,只有当各个数据库文件的checkpoint SCN都相同时,数据库才能打开。

虽然参数“_allow_resetlogs_corruption”可以在checkpoint SCN不一致时强制打开数据库,但是这样的数据库在open后必须马上作全库的export,然后重建数据库并import数据。

当一个检查点动作完成之后,Oracle就把系统检查点的SCN存储到控制文件中。

Resetlog SCN

数据库不完全恢复时,在指定时间点后的SCN都无法再应用到数据库中。Resetlog时的SCN就被设成当前数据库SCNredo log也会被重新设置。

Stop SCN

Stop SCN记录在数据文件头上。当数据库处在打开状态时,stop SCN被设成最大值0xffff.ffffffff。在数据库正常关闭过程中,stop SCN被设置成当前系统的最大SCN值。在数据库打开过程中,Oracle会比较各文件的stop SCNcheckpoint SCN,如果值不一致,表明数据库先前没有正常关闭,需要做恢复。

High and Low SCN

OracleRedo log会顺序纪录数据库的各个变化。一组redo log文件写满后,会自动切换到下一组redo log文件。则上一组redo loghigh SCN就是下一组redo loglow SCN

在视图v$log_history中,sequence#代表redo log的序列号,first_change#表示当前redo loglow SCN,列next_change#表示当前redo loghigh SCN

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

转载于:http://blog.itpub.net/347643/viewspace-619855/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值