数据库复习(第五版)- 第十章 数据库恢复技术

事务定义:

是一组操作序列,要么不做,要么全部完成,是一个不可分割的工作序列。

事务开始:begin transaction

事务提交:commit

事务回滚:rollback

ACID特性:

原子性:事务要么不做,要么全部完成。

一致性:事务执行的结果必须是从数据库的一个一致性状态到另一个一致性状态。

隔离性:一个事务内部对数据对象的操作对其他并发事务是隔离的。

持久性:事务一旦提交,对数据库中的改变就应该是永久的。

为什么需要数据库恢复子系统?作用是什么

因为在数据库中,硬件或软件的故障、操作员的失误以及恶意的破坏是不可避免的,这些故障轻则影响事务的不正确执行,导致数据库中数据的不正确性,重则破坏整个数据库,使数据库中的数据全部丢失。恢复子系统能够使被破坏的数据库恢复到某一正确状态,从而保护数据库的安全性。

故障的种类

事务故障

系统故障

介质故障

计算机病毒

恢复技术

数据转储和登录日志文件。

数据转储的类别

静态转储:

在进行转储时,数据库首先保持无事务运行且处于一致性状态,然后进行转储,在转储期间不允许事务执行,直到转储完成,很显然在转储期间其他事务什么也不能做,降低了事务的并发性,但这保证的转储数据的正确性。

动态转储:

在进行转储时,其他事务可以对数据进行存取或修改,能够提高数据库的可用性和事务的并发性,但这样会导致转储后的后备数据可能不正确有效。只有加上日志文件才能保证数据的正确性。

还有海量转储(全部数据)和增量转储(部分增量数据)

登录日志文件

作用:

1)事务故障和系统故障必须使用日志文件

2)动态转储时需要日志文件保证后备数据的正确性。

规则:

1)必须按照事务的执行时间登记。

2)必须先写日志,后写数据库。

恢复策略

事务故障的恢复

反向扫描日志文件,找到事务的更新操作,对更新操作执行逆操作,如果是插入操作,逆操作就为删除操作,如果是删除操作,逆操作就为插入操作,如果是更新操作,就将更新前的值写入数据库,直到读到事务的开始标志。

系统故障的恢复

正向扫描日志文件 ,将未提交的事务加入UNDO队列 ,将已提交的事务加入REDO队列 ,对UNDO队列的事务执行撤销 操作,对REDO队列的事务执行重做操作。撤销就是反向扫描日志文件并执行逆操作,重做就是正向扫描日志文件并重做事务。

介质故障的恢复

利用后备数据 将数据库恢复到之前 的某一执行性状态,然后利用此时的日志文件 ,对日志文件中已提交的事务进行重做 ,从而恢复到现在的一致性状态。

检查点技术

首先将ACTIVE-LIST放入UNDO队列,从检查点开始,遇到一个新开始的事务先将它放到UNDO队列,若遇到已提交事务的则转入REDO队列,最后对UNDO队列执行撤销操作,对REDO队列执行重做操作。

数据库镜像

用于解决介质故障。

自动将整个数据库或者部分关键数据复制到另一个磁盘,每当主数据库更新时,数据库管理系统自动将更新后的数据复制过去,并由数据库管理系统自动保持数据的一致性。

还可以用于并发操作,当某事务对主数据库中的某数据对象加上排他锁时,其他用户可以读镜像数据库中的数据,而不必等待释放锁。

相关推荐
_Kayo_1 小时前
node.js 学习笔记3 HTTP
笔记·学习
wyiyiyi4 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
CCCC13101634 小时前
嵌入式学习(day 28)线程
jvm·学习
天宇_任4 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
星星火柴9365 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
小狗爱吃黄桃罐头5 小时前
正点原子【第四期】Linux之驱动开发篇学习笔记-1.1 Linux驱动开发与裸机开发的区别
linux·驱动开发·学习
艾莉丝努力练剑6 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
武昌库里写JAVA7 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习
xiep14383335107 小时前
Ubuntu 安装带证书的 etcd 集群
数据库·etcd
杜子不疼.7 小时前
《Python学习之字典(一):基础操作与核心用法》
开发语言·python·学习