最新文章专题视频专题问答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
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle恢复内部原理(简介)

来源:懂视网 责编:小采 时间:2020-11-09 12:44:29
文档

Oracle恢复内部原理(简介)

Oracle恢复内部原理(简介):本文概述了Oracle 7.2版本如何进行数据库恢复。本文读者应当熟悉Oracle 7.2的管理指南。相比于管理指南,本文目的是为了更详细描 Oracle 7 v7.2 恢复大纲 作者:Andrea Borr & Bill Bridge 版本:1 May 3, 1995 摘要 本文概述了Oracl
推荐度:
导读Oracle恢复内部原理(简介):本文概述了Oracle 7.2版本如何进行数据库恢复。本文读者应当熟悉Oracle 7.2的管理指南。相比于管理指南,本文目的是为了更详细描 Oracle 7 v7.2 恢复大纲 作者:Andrea Borr & Bill Bridge 版本:1 May 3, 1995 摘要 本文概述了Oracl

本文概述了Oracle 7.2版本如何进行数据库恢复。本文读者应当熟悉Oracle 7.2的管理指南。相比于管理指南,本文目的是为了更详细描

Oracle 7 v7.2 恢复大纲

作者:Andrea Borr & Bill Bridge

版本:1 May 3, 1995

摘要

本文概述了Oracle 7.2版本如何进行数据库恢复。本文读者应当熟悉Oracle 7.2的管理指南。相比于管理指南,,本文目的是为了更详细描述Oracle恢复用到的算法、数据结构以及一些技术细节。

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

一、简介

Oracle数据库提供了下列两类失败模式下的数据库恢复:

1. 实例失败:丢失了Oracle数据缓存中的数据或者内存中的数据

2. 介质失败:丢失了数据库文件

上面两种模式的任一种失败情景,在恢复的时候想要保证数据库一致性,都有一些前提条件必须满足。

虽然恢复的过程有一些共同点,但前提条件的差异使得恢复的执行也有很大差异:

1. 实例恢复:恢复Oracle数据缓存中丢失的数据

2. 介质恢复:恢复数据库文件丢失的数据

1.1 实例恢复和介质恢复的共同的机制

实例恢复和介质恢复都依赖重做日志。重做日志由一些重做日志线程组成。单实例环境中重做日志只有一个重做线程,并行服务器环境中每个实例都有一个重做线程。

一个重做日志线程指的的是一组存放在操作系统上的文件,文件里记录了该实例对数据库的所有变更——已提交的变更和未提交的变更(后者指还存在Oracle数据缓存区中的数据块变更)。因为实例也修改了回滚段中的块,所以回滚段的变更也记录在重做日志线程中。

实例恢复和介质恢复的第一步都是前滚。前滚属于数据库恢复层面的。在前滚的过程中,重做日志中记录的数据变更被重新应用到数据文件中。因为回滚段的变更也记录在重做日志中,所以前滚过程还会重新构建回滚段块。当前滚结束时,重做日志中记录的所有变更都应用到数据文件上了。此刻,数据块不仅包含了已经提交的数据,也包含了一些未提交的数据。

实例恢复和介质恢复的第二步就是回滚。回滚属于数据库事务层的任务。回滚过程中,回滚段中记录的由前滚导致的未提交的事务所做的修改将被撤销。

1.2 实例失败和恢复,崩溃失败和恢复

实例失败指当实例突然终止时(如因为shutdown abort或主机掉电),实例数据缓存中的内容就都丢失了。

崩溃失败指数据库的所有实例都同时失败。单实例环境中实例失败等同于崩溃失败。崩溃恢复指的是将所有实例都恢复到崩溃前的一致状态。这一切都是在命令alter database open 之后自动进行的,用户无法干预。

实例失败会损害数据库的一致性因为它导致该实例的脏数据丢失。所谓“脏数据”就是指实例数据缓存中的数据块内容比数据文件上的要新。当实例崩溃时,还没有来得及将脏数据写入到数据文件中。之所以导致存在这个脏数据丢失问题是因为Oracle的缓存管理采用的是有利于事务处理性能的算法而不是有利于防止实例崩溃的。如下这些有利于性能调优的缓存管理算法使得实例恢复过程有点复杂:

1. LRU(最近最少使用)缓存替换算法

2. 提交时不强制将脏数据刷新到数据文件中

上面的算法导致实例失败时对数据库完整性的损害体现在如下几点:

A. 在实例崩溃时,数据文件中可能包含一个原子事务修改的所有块中的部分块而不是全部

B. 在实例崩溃时,数据文件中可能包含一些未提交事务修改的块

C. 在实例崩溃时,一些已提交事务修改的块可能还没有刷新到数据文件中,数据文件中包含的是该事务修改之前的数据块。

在实例恢复过程中,数据库恢复层修复了上面的损害点A和C,然后后续的数据库事务层修复了损害点B。

linux

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

Oracle恢复内部原理(简介)

Oracle恢复内部原理(简介):本文概述了Oracle 7.2版本如何进行数据库恢复。本文读者应当熟悉Oracle 7.2的管理指南。相比于管理指南,本文目的是为了更详细描 Oracle 7 v7.2 恢复大纲 作者:Andrea Borr & Bill Bridge 版本:1 May 3, 1995 摘要 本文概述了Oracl
推荐度:
标签: 恢复 原理 数据库
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top