第十章 数据库恢复技术_第1页
第十章 数据库恢复技术_第2页
第十章 数据库恢复技术_第3页
第十章 数据库恢复技术_第4页
第十章 数据库恢复技术_第5页
已阅读5页,还剩25页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第十章数据库恢复技术 10 1事务的基本概念 是用户定义的一个数据库操作序列 这些操作要么全做要么全不做 是一个不可分割的工作单位 事务和程序比较在关系数据库中 一个事务可以是一条或多条SQL语句 也可以包含一个或多个程序 一个程序通常包含多个事务 定义事务 显式定义方式BEGINTRANSACTIONBEGINTRANSACTIONSQL语句1SQL语句1SQL语句2SQL语句2 COMMITROLLBACK隐式方式当用户没有显式地定义事务时 DBMS按缺省规定自动划分事务 原子性 Atomicity 一致性 Consistency 隔离性 Isolation 持续性 Durability 事务的特性 事务是数据库的逻辑工作单位事务中包括的诸操作要么都做 要么都不做 原子性 一致性状态 数据库中只包含成功事务提交的结果不一致状态 数据库中包含失败事务的结果 一致性 事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态 例 银行转帐中 从帐号A中取出一万元 存入帐号B 定义一个事务 该事务包括两个操作这两个操作要么全做 要么全不做全做或者全不做 数据库都处于一致性状态 如果只做一个操作 数据库就处于不一致性状态 一个事务内部的操作及使用的数据对其他并发事务是隔离的并发执行的各个事务之间不能互相干扰 隔离性 持续性 一个事务一旦提交 它对数据库中数据的改变就应该是永久性的 接下来的其他操作或故障不应该对其执行结果有任何影响 事务遭破坏的因素 1 多个事务并行运行时 不同事务的操作交叉执行 2 事务在运行过程中被强行停止 10 2数据库恢复概述 数据库管理系统具有的把数据库从错误状态恢复到某一已知的正确状态的功能 就是数据库的恢复 10 3故障的种类 事务内部的故障系统故障介质故障计算机病毒 10 4恢复的实现技术 如何建立冗余数据数据转储登录日志文件如何利用这些冗余数据实施数据库恢复 10 4 1数据转储 由DBA定期地将整个数据库复制到磁盘上保存起来的过程 备用的数据文本称为后备副本或后援副本 静态转储 在系统中无运行事务时进行的转储操作 动态转储 指转储期间允许对数据库进行存取或修改 正常运行 恢复 转储 运行事务 故障发生点 重装后备副本 重装运行事务 Ta Tb Tf 数据转储分类 10 4 2登记日志文件 日志文件是用来记录事务对数据库的更新操作的文件 以记录为单位的日志文件以数据块为单位的日志文件 日志文件登记的内容 各个事务的开始标记各个事务的结束标记各个事务的所有更新操作 日志记录的内容 事务标识操作的类型操作对象更新前数据的旧值更新后数据的新值 日志文件的作用 事务故障恢复和系统故障恢复必须用日志文件 在动态转储方式中必须建立日志文件 后援副本和日志文件综合起来才能有效地恢复数据库 在静态转储过程中 也可以建立日志文件 登记日志文件 原则登记的次序严格按并发事务执行的时间次序 必须先写日志文件 后写数据库 10 5恢复策略 10 5 1事务故障的恢复 撤消 UNDO 反向扫描文件日志 查找该事务的更新操作 对该事务的更新操作执行逆操作 继续反向扫描日志文件 查找该事务的其他更新操作 并做同样处理 如此处理下去 直至读到此事务的开始标记 事务故障恢复就完成了 10 5 2系统故障的恢复 正向扫描日志文件 找出在故障发生前已经提交的事务 将其事务标识记入重做 REDO 队列 同时找出尚未完成的事务 将其事务标识记入撤消 UNDO 队列 对撤消队列中的各个事务进行撤消 UNDO 处理 对重做队列中的各个事务进行重做 REDO 处理 10 5 3介质故障的恢复 装入最新的数据库后备副本 使数据库恢复到最近一次转储时的一致性状态 装入响应的日志文件副本 重做已完成的事务 10 6具有检查点的恢复技术 在日志文件中增加检查点记录 内容包括 1 建立检查点时刻所有正在执行的事务清单 2 这些事务最近一个日志记录的地址 增加一个重新开始文件 用来记录各个检查点记录在日志文件中的地址 10 6具有检查点的恢复技术 检查点Ci的重新开始记录 日志记录日志记录T1D1T2D2 Ci检查点记录地址 检查点记录 重新开始文件 日志文件 10 6具有检查点的恢复技术 动态维护日志文件的方法是周期性地执行如下操作 建立检查点 保存数据库状态 1 将当前日志缓冲中的所有日志记录写入磁盘的日志文件上 2 在日志文件中写入一个检查点记录 3 将当前数据缓冲的所有数据记录写入磁盘的数据库中 4 把检查点记录在日志文件中的地址写入一个重新开始文件 10 6具有检查点的恢复技术 Tc 检查点 Tf 系统故障 时间 T1 T2 T3 T4 T5 REDO UNDO REDO UNDO 恢复子系统采取的不同措施 10 6具有检查点的恢复技术 检查点恢复的步骤 1 从重新开始文件中找到最后一个检查点记录在日志文件中的地址 由该地址在日志文件中找到最后一个检查点记录 2 由该检查点记录得到检查点建立时刻所有正在执行的事务清单ACTIVE LIST 建立两个事务队列 UNDO LISTREDO LIST把ACTIVE LIST暂时放入UNDO LIST队列 REDO队列暂时为空 10 6具有检查点的恢复技术 3 从检查点开始正向扫描日志文件如有新开始的事务Ti 把Ti暂时放入UNDO LIST队列 如有提交的事务Tj 把Tj从UNDO LIST队列移到REDO LIST队列 直到日志文件结束 4 对UNDO LIST中的每个事务执行UNDO操作 对REDO LIST中的每个事务执行REDO操作 Tc 检查

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论