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

事务定义:

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

事务开始:begin transaction

事务提交:commit

事务回滚:rollback

ACID特性:

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

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

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

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

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

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

故障的种类

事务故障

系统故障

介质故障

计算机病毒

恢复技术

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

数据转储的类别

静态转储:

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

动态转储:

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

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

登录日志文件

作用:

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

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

规则:

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

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

恢复策略

事务故障的恢复

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

系统故障的恢复

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

介质故障的恢复

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

检查点技术

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

数据库镜像

用于解决介质故障。

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

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

相关推荐
STLearner3 分钟前
AI论文速读 | QuitoBench:支付宝高质量开源时间序列预测基准测试集
大数据·论文阅读·人工智能·深度学习·学习·机器学习·开源
2301_795099743 分钟前
HTML怎么创建时间轴布局_HTML结构化时间线写法【方法】
jvm·数据库·python
运气好好的6 分钟前
CSS组件库如何快速扩展_通过Sass @extend继承基础布局
jvm·数据库·python
m0_6138562914 分钟前
Go install 命令失效原因解析与正确使用指南
jvm·数据库·python
星马梦缘19 分钟前
数据库作战记录6 实验6
数据库·oracle
AC赳赳老秦20 分钟前
DBA 专属方案:用 OpenClaw 实现 SQL 语句优化、慢查询分析、数据库备份巡检全自动化
服务器·前端·数据库·ffmpeg·自动化·deepseek·openclaw
学术阿凡提20 分钟前
Spring Boot 优雅实现异步调用:从入门到自定义线程池与异常处理
java·数据库·算法
夏末蝉未鸣0122 分钟前
跨境电商SQL Server报表生成优化:索引一改,600秒变75秒
数据库
hhb_61835 分钟前
SQL高性能查询优化与复杂场景实战指南
服务器·数据库·sql
醇氧36 分钟前
WSL2(Windows Subsystem for Linux ) 从入门到实践指南
linux·运维·服务器·windows·学习