块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,用户几乎感觉不到。
7.1 块修复初始化和操作
前台进程在修改一个缓冲区的时候调用重做程序在该缓冲区上应用改变向量时因为前台进程僵死或者触发一个错误而导致缓冲区的状态不一致,块修复就是用来修复这种缓冲区的状态。修复的过程包括:(i)从磁盘上读取该块;(ii)用当前线程的重做日志重新构建该缓冲区的一致版本;(iii)将修复的块写回磁盘。如果块修复第一次失败了,会再尝试第二次,然后将该块标识为逻辑损坏(将该块的序号置为0),然后触发一个块损坏的错误。
块修复使用当前线程的重做日志构建缓冲区是可行的,因为:
- 块修复不能使用其他线程的重做日志或者当前线程最后一次检查点之前的重做日志。
- 直到当前线程检查点超出日志,联机日志才不会重用。
- 数据缓冲区中的都不需要从最后一次线程检查点之前的重做日志进行恢复。
7.2 缓冲区头部RBA 字段
缓冲区头(一个内存数据结构)包含下面这些跟块修复有关的字段:
Low-RBA和High-RBA:Low-RBA是从该数据块最后一次块清除操作以来应用的第一个重做日志的地址,High-RBA是该数据块最新的变更对应重做日志的地址。二者结合起来描述了将该数据块从磁盘上的版本变成最新的版本所需要的重做日志范围。
Recovery-RBA:当执行块修复的是PMON进程时且完成所有的块修复可能需要很长时间就用Recover-RBA来记录进度的。
7.3 PMON 和前台进程调用
如果前台进程在回调重做日志程序时前台进程报错,将由前台进程执行块修复;如果前台进程不是报错而是僵死了,将由PMON进程执行块修复。
块修复可能需要大量的时间和I/O。不过PMON进程可以有充足的时间做块修复而忽略其他紧急任务。因此对每次PMON执行块修复使用重做日志的量有个限制(一个常量指定了每次PMON调用可以使用的重做日志块的数量)。每次PMON执行块修复应用完最大的重做日志后,都会更新数据缓冲区的 Recovery-RBA字段以记录它的进度。当Recovery-RBA值达到High-RBA的值后,针对这个块的块修复过程结束。
继第八章Oracle恢复内部原理(重置日志resetlogs)
**********本博客所有内容均为原创,如有转载请注明作者和出处!!!**********
Name: guoyJoe
QQ: 252803295
Email: oracledba_cn@hotmail.com
Blog:http://blog.csdn.net/guoyJoe
ITPUB:http://www.itpub.net/space-uid-28460966.html
OCM:http://education.oracle.com/education/otn/YGuo.HTM
_____________________________________________________________
加群验证问题:哪些SGA结构是必需的,哪些是可选的?否则拒绝申请!!!
答案在:http://blog.csdn.net/guoyjoe/article/details/8624392
Oracle@Paradise 总群:127149411
Oracle@Paradise No.1群:177089463(已满)
Oracle@Paradise No.2群:121341761
Oracle@Paradise No.3群:140856036
分享到:
相关推荐
Oracle 坏块修复 Oracle 坏块 总结
Oracle数据块原理分析
ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训ORACLE内部培训...
Oracle恢复误删除数据 Oracle恢复误删除数据 Oracle恢复误删除数据
第7章 数据库保护 第8章 ORACLE的企业管理器(Enterprise Manager) 第9章 分布式数据库系统 第10章 数据库应用程序开发工具-ORACLE Developer 第11章 ORACLE J2EE高级技术与JDeveloper 第12章 ORACLE程序实例...
oracle数据块损坏及恢复,模拟了坏块报错,调整事件绕过坏块
《oracle dba手记3:数据库性能优化与内部原理解析》由多位数据库技术专家合著而成,融合了各行业dba 的工作经验与思考,包含了精心挑选的数据库性能优化与内部原理解析案例。内容涵盖“dba 手记”,以手记形式记录...
oraclerman备份原理[参照].pdf
oracle重做日志原理
oracle 索引的原理原理深入理解!
Oracle恢复流程图Oracle恢复流程图Oracle恢复流程图
Oracle 修复数据库中的坏块Oracle 修复数据库中的坏块
老方块ORACLE 内部培训.zip
Oracle数据块原理深入理解,带你了解ORACLE底层的知识
oracle恢复原理;oracle培训内部资料,数据库爱好者非常值得一看.
任何数据库在长期使用过程中,都会存在一定的安全隐患。对于数据库管理员来说不能仅寄希望于计算机操作系统的安全运行,而是要建立一整套的数据库备份与恢复机制。...第七章 RMAN恢复 第八章 备份恢复示例
完整版Oracle11数据库教程课件 第7章_高级查询(共52页).ppt 完整版Oracle11数据库教程课件 第8章_索引视图(共35页).ppt 完整版Oracle11数据库教程课件 第9章_PLSQL编程基础(共59页).ppt 完整版Oracle11数据库...
oracle介质恢复的内部过程--推断与参考 这个是两年前学习oracle总结的东西,不算什么新东西,仅作为个人的一个记录,也欢迎大家一起学习讨论。
arcsde 操作oracle的操作原理