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

事务定义:

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

事务开始:begin transaction

事务提交:commit

事务回滚:rollback

ACID特性:

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

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

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

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

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

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

故障的种类

事务故障

系统故障

介质故障

计算机病毒

恢复技术

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

数据转储的类别

静态转储:

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

动态转储:

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

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

登录日志文件

作用:

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

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

规则:

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

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

恢复策略

事务故障的恢复

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

系统故障的恢复

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

介质故障的恢复

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

检查点技术

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

数据库镜像

用于解决介质故障。

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

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

相关推荐
枫叶丹43 分钟前
破局政务数字化核心难题:金仓数据库以国产化方案引领电子证照系统升级之路
数据库·政务·1024程序员节·金仓
小志biubiu5 分钟前
linux_缓冲区及简单libc库【Ubuntu】
linux·运维·服务器·c语言·学习·ubuntu·c
托比-马奎尔6 分钟前
Redis主从集群
数据库·redis·缓存
码力引擎1 小时前
【零基础学MySQL】第一章:MySQL介绍与安装
数据库·mysql·1024程序员节
小超嵌入式笔记1 小时前
【Keil5教程及技巧】耗时一周精心整理万字全网最全Keil5(MDK-ARM)功能详细介绍【建议收藏-细细品尝】
java·数据库·mongodb
hweiyu002 小时前
Node.js+Koa2+MySQL 打造前后端分离项目(视频教程)
数据库·mysql·node.js
奋斗的牛马2 小时前
FPGA—ZYNQ学习GPIO-EMIO(三)
学习·fpga开发
py有趣2 小时前
LeetCode算法学习之合并区间
学习·算法·leetcode
青衫码上行2 小时前
【Java Web学习 | 第1篇】前端 - HTML
java·前端·学习
charlie1145141912 小时前
HTML 理论笔记
开发语言·前端·笔记·学习·html·1024程序员节