最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle恢复内部原理(块修复)

来源:动视网 责编:小采 时间:2020-11-09 10:51:11
文档

Oracle恢复内部原理(块修复)

Oracle恢复内部原理(块修复):块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,用户几乎感觉不到。 块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,用户几乎感觉不到。 系列文章:Oracle恢复内部原理 where=nkey&keyword=19824 7.1 块修复初
推荐度:
导读Oracle恢复内部原理(块修复):块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,用户几乎感觉不到。 块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,用户几乎感觉不到。 系列文章:Oracle恢复内部原理 where=nkey&keyword=19824 7.1 块修复初


块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,用户几乎感觉不到。

块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,,用户几乎感觉不到。

系列文章:Oracle恢复内部原理 ?where=nkey&keyword=19824

7.1 块修复初始化和操作

前台进程在修改一个缓冲区的时候调用重做程序在该缓冲区上应用改变向量时因为前台进程僵死或者触发一个错误而导致缓冲区的状态不一致,块修复就是用来修复这种缓冲区的状态。修复的过程包括:(i)从磁盘上读取该块;(ii)用当前线程的重做日志重新构建该缓冲区的一致版本;(iii)将修复的块写回磁盘。如果块修复第一次失败了,会再尝试第二次,然后将该块标识为逻辑损坏(将该块的序号置为0),然后触发一个块损坏的错误。

块修复使用当前线程的重做日志构建缓冲区是可行的,因为:

1.块修复不能使用其他线程的重做日志或者当前线程最后一次检查点之前的重做日志。

2.直到当前线程检查点超出日志,联机日志才不会重用。

3.数据缓冲区中的都不需要从最后一次线程检查点之前的重做日志进行恢复。

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恢复内部原理(块修复)

Oracle恢复内部原理(块修复):块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,用户几乎感觉不到。 块修复是最简单的恢复,在数据库正常操作过程中由系统自动做的,用户几乎感觉不到。 系列文章:Oracle恢复内部原理 where=nkey&keyword=19824 7.1 块修复初
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top