《数据库系统》第5版原版授课-第10章研讨.ppt

《数据库系统》第5版原版授课-第10章研讨.ppt

  1. 1、本文档共98页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
10.8 小结 事务的概念和性质 事务是数据库的逻辑工作单位 数据库管理系统保证系统中一切事务的原子性、一致性、隔离性和持续性,就保证了事务处于一致状态 小结(续) 故障的种类 事务故障 系统故障 介质故障 恢复中最经常使用的技术 数据库转储 登记日志文件 小结(续) 恢复的基本原理 利用存储在后备副本、日志文件和数据库镜像中的冗余数据来重建数据库 事务 不仅是恢复的基本单位 也是并发控制的基本单位 事务故障的恢复步骤(续) (3) 继续反向扫描日志文件,查找该事务的其他更新操作,并做同样处理。 (4) 如此处理下去,直至读到此事务的开始标记,事务故障恢复就完成了。 参见爱课程网10.3节动画《事务故障及其恢复 》 10.5 恢复策略 10.5.1 事务故障的恢复 10.5.2 系统故障的恢复 10.5.3 介质故障的恢复 10.5.2 系统故障的恢复 系统故障造成数据库不一致状态的原因 未完成事务对数据库的更新可能已写入数据库 已提交事务对数据库的更新可能还留在缓冲区没来得及写入数据库 恢复方法 1. Undo 故障发生时未完成的事务 2. Redo 已完成的事务 系统故障的恢复由系统在重新启动时自动完成,不需要用户干预 系统故障的恢复步骤 (1)正向扫描日志文件(即从头扫描日志文件) 重做(REDO) 队列: 在故障发生前已经提交的事务 这些事务既有BEGIN TRANSACTION记录,也有COMMIT记录 撤销 (UNDO)队列:故障发生时尚未完成的事务 这些事务只有BEGIN TRANSACTION记录,无相应的COMMIT记录 系统故障的恢复步骤(续) (2) 对撤销(UNDO)队列事务进行撤销(UNDO)处理 反向扫描日志文件,对每个撤销事务的更新操作执行逆操作 即将日志记录中“更新前的值”写入数据库 (3)对重做(REDO)队列事务进行重做(REDO)处理 正向扫描日志文件,对每个重做事务重新执行登记的操作 即将日志记录中“更新后的值”写入数据库 参见爱课程网10.3节动画《系统故障及其恢复 》 10.5 恢复策略 10.5.1 事务故障的恢复 10.5.2 系统故障的恢复 10.5.3 介质故障的恢复 10.5.3 介质故障的恢复 1.重装数据库 2.重做已完成的事务 介质故障的恢复(续) 恢复步骤 (1) 装入最新的后备数据库副本(离故障发生时刻最近的转储副本) ,使数据库恢复到最近一次转储时的一致性状态。 对于静态转储的数据库副本,装入后数据库即处于一致性状态 对于动态转储的数据库副本,还须同时装入转储时刻的日志文件副本,利用恢复系统故障的方法(即REDO+UNDO),才能将数据库恢复到一致性状态。 介质故障的恢复(续) (2) 装入有关的日志文件副本(转储结束时刻的日志文件副本) ,重做已完成的事务。 首先扫描日志文件,找出故障发生时已提交的事务的标识,将其记入重做队列。 然后正向扫描日志文件,对重做队列中的所有事务进行重做处理。即将日志记录中“更新后的值”写入数据库。 介质故障的恢复(续) 介质故障的恢复需要数据库管理员介入 数据库管理员的工作 重装最近转储的数据库副本和有关的各日志文件副本 执行系统提供的恢复命令 具体的恢复操作仍由数据库管理系统完成 参见爱课程网10.3节动画《介质故障及其恢复 》 第十章 数据库恢复技术 10.1 事务的基本概念 10.2 数据库恢复概述 10.3 故障的种类 10.4 恢复的实现技术 10.5 恢复策略 10.6 具有检查点的恢复技术 10.7 数据库镜像 10.8 小结 10.6 具有检查点的恢复技术 1.问题的提出 2.检查点技术 3.利用检查点的恢复策略 1.问题的提出 两个问题 搜索整个日志将耗费大量的时间 重做处理:重新执行,浪费了大量时间 解决方案 具有检查点(checkpoint)的恢复技术 在日志文件中增加检查点记录(checkpoint) 增加重新开始文件 恢复子系统在登录日志文件期间动态地维护日志 2.检查点技术 检查点记录的内容 建立检查点时刻所有正在执行的事务清单 这些事务最近一个日志记录的地址 重新开始文件的内容 记录各个检查点记录在日志文件中的地址 检查点技术(续) 具有检查点的日志文件和重新开始文件 动态维护日志文件的方法 动态维护日志文件的方法 周期性地执行如下操作:建立检查点,保存数据库状态。 具体步骤是: (1)将当前日志缓冲区中的所有日志记录写入磁盘的日志文件上 (2)在日志文件中写入一个检查点记录 (3)将当前数据缓冲区的所有数据记录写入磁盘的数据库中 (4)把检查点记录在日志文件中的地址写入一个重新开始文件 建立检查点 恢复子系统可以定期或不定期地建立

文档评论(0)

希望之星 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档