第五节 恢复策略
5.5.1 事务故障的恢复
事务故障:事务在运行至正常终止点前被中止。
恢复方法:由恢复子系统应利用日志文件撤消(UNDO)此事务已对数据库进行的修改,事务故障的恢复
由系统自动完成,不需要用户干预。
事务故障的恢复步骤:
1. 反向扫描文件日志(即从最后向前扫描日志文件),查找该事务的更新操作。
2. 对该事务的更新操作执行逆操作。即将日志记录中“更新前的值”(Befor Image, BI)写入数据库。
插入操作, “更新前的值”为空,则相当于做删除操作。删除操作,“更新后的值”为空,则相当于做插入
操作。若是修改操作,则用BI 代替 AI(After Image)。
3. 继续反向扫描日志文件,查找该事务的其他更新操作,并做同样处理。
4. 如此处理下去,直至读到此事务的开始标记,事务故障恢复就完成了。
5.5.2 系统故障的恢复
系统故障造成数据库不一致状态的原因,一些未完成事务对数据库的更新已写入数据库,一些已提交事
务对数据库的更新还留在缓冲区没来得及写入数据库。恢复方法:
1. Undo 故障发生时未完成的事务。
2. Redo 已完成的事务。
系统故障的恢复由系统在重新启动时自动完成,不需要用户干预。系统故障的恢复步骤:
1. 正向扫描日志文件(即从头扫描日志文件)。
Redo队列: 在故障发生前已经提交的事务,
T1, T3, T8…..
Undo队列:故障发生时尚未完成的事务。
T2, T4, T5, T6, T7, T9 …...
2. 对Undo队列事务进行UNDO处理
反向扫描日志文件,对每个UNDO事务的更新操作执行逆操作。
T2, T4, T5, T6, T7, T9 ……
3. 对Redo队列事务进行REDO处理
正向扫描日志文件,对每个REDO事务重新执行登记的操作。
T1, T3, T8…..
5.5.3 介质故障的恢复
1. 重装数据库,使数据库恢复到一致性状态。
2. 重做已完成的事务
恢复步骤:
1. 装入最新的后备数据库副本,使数据库恢复到最近一次转储时的一致性状态。对于静态转储的数据
库副本,装入后数据库处于一致性状态。对于动态转储的数据库副本,还须同时装入转储时刻的日志文件副
本,利用与恢复系统故障相同的方法(即REDO+UNDO),才能将数据库恢复到一致性状态。
2. 装入有关的日志文件副本,重做已完成的事务。首先扫描日志文件,找出故障发生时已提交的事务
的标识,将其记入重做队列。然后正向扫描日志文件,对重做队列中的所有事务进行重做处理。即将日志记
录中“更新后的值”写入数据库。介质故障的恢复需要DBA介入。DBA的工作,重装最近转储的数据库副本和
有关的各日志文件副本,执行系统提供的恢复命令,具体的恢复操作仍由DBMS完成。
|