故障恢复 事务的.doc

上传人:sk****8 文档编号:3101956 上传时间:2019-05-21 格式:DOC 页数:6 大小:1.55MB
下载 相关 举报
故障恢复 事务的.doc_第1页
第1页 / 共6页
故障恢复 事务的.doc_第2页
第2页 / 共6页
故障恢复 事务的.doc_第3页
第3页 / 共6页
故障恢复 事务的.doc_第4页
第4页 / 共6页
故障恢复 事务的.doc_第5页
第5页 / 共6页
点击查看更多>>
资源描述

1、三种数据不一致: 丢失修改: (写写):一级封锁读“脏”数据:(写读):二级封锁不可重复读: (读写):三级封锁一级封锁协议:事务在修改数据之前先对其加 X 锁,直到事务结束才释放。二级封锁协议:一级协议的基础上,加上事务读数据之前先对其加 S 锁,读完后即可释放。三级封锁协议:一级协议的基础上,加事务读数据之前先对其加 S 锁,直到事务结束。三级封锁协议(保持数据的一致性)两段锁协议(保证并行调度可串行性)1 在数据库中为什么要并发控制?答:数据库是共享资源,通常有许多个事务同时在运行。当多个事务并发地存取数据库时就会产生同时读取和或修改同一数据的情况。若对并发操作不加控制就可能会存取和存储

2、不正确的数据,破坏数据库的一致性。所以数据库管理系统必须提供并发控制机制。2 并发操作可能会产生哪几类数据不一致?用什么方法能避免各种不一致的情况?答:并发操作带来的数据不一致性包括三类:丢失修改、不可重复读和读“脏夕数据。 ( l )丢失修改(lost update ) 两个事务 Tl 和 T2 读入同一数据并修改, T2 提交的结果破坏了(覆盖了) Tl 提交的结果,导致 Tl 的修改被丢失。 ( 2 )不可重复读( Non 一 Repeatable Read ) 不可重复读是指事务 Tl 读取数据后,事务几执行更新操作,使 Tl 无法再现前一次读取结果。( 3 )读“脏”数据( Dirt

3、y Read ) 读“脏夕数据是指事务 Tl 修改某一数据,并将其写回磁盘,事务几读取同一数据后, Tl 由于某种原因被撤销,这时 Tl 已修改过的数据恢复原值,几读到的数据就与数据库中的数据不一致,则几读到的数据就为“脏”数据,即不正确的数据。避免不一致性的方法和技术就是并发控制。最常用的技术是封锁技术。也可以用其他技术,例如在分布式数据库系统中可以采用时间戳方法来进行并发控制。 3 什么是封锁?基本的封锁类型有几种?试述它们的含义。答:封锁就是事务 T 在对某个数据对象例如表、记录等操作之前,先向系统发出请求,对其加锁。加锁后事务 T 就对该数据对象有了一定的控制,在事务 T 释放它的锁之

4、前,其他的事务不能更新此数据对象。封锁是实现并发控制的一个非常重要的技术。排它锁:又称为写锁(eXclusive lock)若事务 T 对数据对象 A 加上 X 锁,则只允许 T 读取和修改 A 其它任何事务都不能再对 A 加任何类型的锁,直到 T 释放 A 上的锁。共享锁:又称为读锁(Share lock)若事务 T 对数据对象 A 加上 S 锁,T 可以读取 A 其它事务只能再对 A 加 S 锁,而不能加 X 锁,直到 T 释放 A 上的 S 锁。活锁:当某个事务请求对某一数据的排它性封锁时,由于其他事务对该数据的操作而使这个事务处于永久等待状态,这种状态称为活锁。 先来先服务原则。死锁:

5、系统中有两个或两个以上的事务都处于等待状态,其中的每一个事务在它能够执行之前,都在等待着另一个事务解除封锁,结果造成任何一个事务都无法继续执行,这种状态称为死锁。 一次封锁法和顺序封锁法。可串行化调度:多个事务的并发执行时正确的,当且仅当其结果与按某一次序串行的执行这些事务时的结果相同,称这种调度策略为可串行化的调度。可串行化的调度一定是正确的。4 如何用封锁机制保证数据的一致性?答: DBMS 在对数据进行读、写操作之前首先对该数据执行封锁操作,例如下图中事务 Tl 在对 A 进行修改之前先对 A 执行 xock ( A ) ,即对 A 加 x 锁。这样,当几请求对 A 加 x 锁时就被拒绝

6、,几只能等待 Tl 释放 A 上的锁后才能获得对 A 的 x 锁,这时它读到的 A 是 Tl 更新后的值,再按此新的 A 值进行运算。这样就不会丢失 Tl 的更新。DBMS 按照一定的封锁协议,对并发操作进行控制,使得多个并发操作有序地执行,就可以避免丢失修改、不可重复读和读“脏夕数据等数据不一致性。9 设 Tl ,T2,T3 是如下的 3 个事务,设 A 的初值为 0, Tl :A : = A + 2 ; T2:A : = A * 2 ; T3:A : = A *2 ; ( A -A*A)( l )若这 3 个事务允许并行执行,则有多少可能的正确结果,请一一列举出来。答 :A 的最终结果可能

7、有 2 、 4 、 8 、 16 。因为串行执行次序有 Tl T2T3、 Tl T3T2、T2T1T3、T2T3Tl 、T3T1T2 、T3T2 Tl 。对应的执行结果是 16 、 8 4 2 4 2 。 ( 2 )请给出一个可串行化的调度,并给出执行结果最后结果 A 为 16 ,是可串行化的调度。( 4 )若这 3 个事务都遵守两段锁协议,请给出一个不产生死锁的可串行化调度。1试述事务的概念及事务的 4 个特性。答:事务:是作为单个逻辑工作单元执行的一系列数据库操作,操作序列作为一个整体一起向系统提交,要么都执行、要么都不执行,一个不可分割的操作单位。事务具有 4 个特性: ACID 特性。

8、原子性:事务是数据库的逻辑工作单位,事务中包括的诸操作要么都做,要么都不做。一致性:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。隔离性:一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对其他并发事务是隔离的,并发执行的各个事务之间不能互相干扰。持续性:持续性也称永久性(Perfnanence ) ,指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其执行结果有任何影响。4 数据库运行中可能产生的故障有哪几类?答:(1)事务内部的故障;(2)系统故障;(3)介质故障;(4)计算机病毒。 事务故障、系统故障和介质故障影

9、响事务的正常执行;介质故障和计算机病毒破坏数据库数据。5.系统故障造成数据不一致状态的原因有两个,一是未完成事务对数据库的更新可能已写入数据库,二是已提交事务对数据库的更新可能还留在缓冲区没来的及写入数据库。5 数据库恢复的基本技术有哪些?答:数据转储和登录日志文件是数据库恢复的基本技术。当系统运行过程中发生故障,利用转储的数据库后备副本和日志文件就可以将数据库恢复到故障前的某个一致性状态。6 数据库转储的意义是什么?试比较各种数据转储方法。答:数据转储是数据库恢复中采用的基本技术。所谓转储即 DBA 定期地将数据库复制到磁带或另一个磁盘上保存起来的过程。当数据库遭到破坏后可以将后备副本重新装

10、入,将数据库恢复到转储时的状态。静态转储:在系统中无运行事务时进行的转储操作,如上图所示。静态转储简单,但必须等待正运行的用户事务结束才能进行。同样,新的事务必须等待转储结束才能执行。显然,这会降低数据库的可用性。动态转储:指转储期间允许对数据库进行存取或修改。动态转储可克服静态转储的缺点,它不用等待正在运行的用户事务结束,也不会影响新事务的运行。但是,转储结束时后援副本上的数据并不能保证正确有效。因为转储期间运行的事务可能修改了某些数据,使得后援副本上的数据不是数据库的一致版本。为此,必须把转储期间各事务对数据库的修改活动登记下来,建立日志文件( 109 file ) 。这样,后援副本加上日

11、志文件就能得到数据库某一时刻的正确状态。转储还可以分为海量转储和增量转储两种方式。海量转储是指每次转储全部数据库。增量转储则指每次只转储上一次转储后更新过的数据。从恢复角度看,使用海量转储得到的后备副本进行恢复一般说来更简单些。但如果数据库很大,事务处理又十分频繁,则增量转储方式更实用更有效。7 什么是日志文件?为什么要设立日志文件?答:(1)日志文件是用来记录事务对数据库的更新操作的文件。 (2)设立日志文件的目的是:进行事务故障恢复;进行系统故障恢复;协助后备副本进行介质故障恢复。8 登记日志文件时为什么必须先写日志文件,后写数据库?答:把对数据的修改写到数据库中和把表示这个修改的日志记录

12、写到日志文件中是两个不同的操作。有可能在这两个操作之间发生故障,即这两个写操作只完成了一个。如果先写了数据库修改,而在运行记录中没有登记这个修改,则以后就无法恢复这个修改了。如果先写日志,但没有修改数据库,在恢复时只不过是多执行一次 UNDO 操作,并不会影响数据库的正确性。所以一定要先写日志文件,即首先把日志记录写到日志文件中,然后写数据库的修改。9 针对不同的故障,试给出恢复的策略和方法。 (即如何进行事务故障的恢复?系统故障的恢复?介质故障恢复?) 答:系统故障的恢复: 系统故障可能会造成数据库处于不一致状态:一是未完成事务对数据库的更新可能已写入数据库;二是已提交事务对数据库的更新可能

13、还留在缓冲区,没来得及写入数据库。因此恢复操作就是要撤销(UNDO )故障发生时未完成的事务,重做(REDO )已完成的事务。系统的恢复步骤是:(1)正向扫描日志文件,找出在故障发生前已经提交的事务队列(REDO 队列)和未完成的事务队列(uNDO 队列) 。 (2)对撤销队列中的各个事务进行UNDO 处理。进行 UNDO 处理的方法是,反向扫描日志文件,对每个 UNDO 事务的更新操作执行逆操作,即将日志记录中“更新前的值”Before Image )写入数据库。( 3 )对重做队列中的各个事务进行 REDO 处理。 进行 REDO 处理的方法是:正向扫描日志文件,对每个 REDO 事务重新执行日志文件登记的操作。即将日志记录中“更新后的值”Afte , Image )写入数据库。介质故障的恢复:介质故障是最严重的一种故障。恢复方法是重装数据库,然后重做已完成的事务。具体过程是:( 1 ) DBA 装入最新的数据库后备副本(离故障发生时刻最近的转储副本), 使数据库恢复到转储时的一致性状态;( 2 ) DBA 装入转储结束时刻的日志文件副本;( 3 ) DBA 启动系统恢复命令,由 DBMS 完成恢复功能,即重做已完成的事务。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育教学资料库 > 精品笔记

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。