数据库原理第十章数据库恢复技术
- 格式:ppt
- 大小:1.11 MB
- 文档页数:68
数据库恢复技术及其实现方法数据库恢复技术是数据库管理系统中的核心功能之一,它负责将数据库从故障或者错误中恢复并使其重新可用。
在现代社会中,数据库的重要性不言而喻,因此数据库恢复技术的研究和实践显得尤为重要。
本文将介绍数据库恢复技术的一些常见方法及其实现方式,以期对读者有所帮助。
一、日志恢复技术日志恢复技术是一种常见的数据库恢复方法,它通过事务日志(transaction log)记录以及回滚操作,实现数据库的恢复。
在数据库系统中,事务日志记录了每个事务所执行的操作,包括数据的插入、修改和删除等。
通过事务日志,可以回溯到数据库发生错误前的状态,从而进行恢复。
实现方式:1. 重做(Redo)恢复:该方法是通过重新执行已经提交的事务日志来进行恢复。
当数据库发生故障时,系统会检查事务日志中未提交的事务并将其重新执行,以保证数据库的一致性和完整性。
2. 撤销(Undo)恢复:与重做恢复相反,撤销恢复是对未提交的事务进行回滚操作,将其撤回到故障发生前的状态。
通过撤销恢复,数据库可以回滚到一个更稳定的状态。
二、快照(Snapshot)恢复技术快照恢复技术是另一种常见的数据库恢复方法,它通过保存数据库的快照(即某个时间点的数据库状态)来实现恢复。
当数据库发生故障时,可以将数据库恢复到之前某个时间点的快照状态,从而达到修复的目的。
实现方式:1. 冷备份(Cold Backup):该方法是在数据库关闭的情况下进行备份,通过将数据库文件复制到其他位置来保存数据库的快照。
当数据库发生故障时,可以使用备份文件来还原数据库。
2. 热备份(Hot Backup):与冷备份不同,热备份是在数据库运行期间进行备份,而不需要关闭数据库。
通过使用特殊的备份工具,可以在数据库运行的同时备份数据库文件,并保持数据库的一致性。
三、镜像(Mirroring)恢复技术镜像恢复技术是一种高可用性的数据库恢复方法,它通过实时复制数据库到备份服务器中,以实现快速恢复。
数据库恢复技术---恢复内容开始---数据库恢复技术事务:是⽤户定义的⼀个数据库操作序列,这些操作要么全做,要么全不做,是⼀个不可分割的⼯作单位。
事物的 ACID 特性:原⼦性、⼀致性、隔离性、持续性。
恢复的实现技术:建⽴冗余数据 -> 利⽤冗余数据实施数据库恢复。
建⽴冗余数据常⽤技术:数据转储(动态海量转储、动态增量转储、静态海量转储、静态增量转储)、登记⽇志⽂件。
ACID特性1. 原⼦性(Atomicity)⼀个原⼦事务要么完整执⾏,要么⼲脆不执⾏。
这意味着,⼯作单元中的每项任务都必须正确执⾏。
如果有任⼀任务执⾏失败,则整个⼯作单元或事务就会被终⽌。
即此前对数据所作的任何修改都将被撤销。
如果所有任务都被成功执⾏,事务就会被提交,即对数据所作的修改将会是永久性的。
2. ⼀致性(Consistency)⼀致性代表了底层数据存储的完整性。
它必须由事务系统和应⽤开发⼈员共同来保证。
事务系统通过保证事务的原⼦性,隔离性和持久性来满⾜这⼀要求; 应⽤开发⼈员则需要保证数据库有适当的约束(主键,引⽤完整性等),并且⼯作单元中所实现的业务逻辑不会导致数据的不⼀致(即,数据预期所表达的现实业务情况不相⼀致)。
例如,在⼀次转账过程中,从某⼀账户中扣除的⾦额必须与另⼀账户中存⼊的⾦额相等。
3. 隔离性(Isolation)隔离性意味着事务必须在不⼲扰其他进程或事务的前提下独⽴执⾏。
换⾔之,在事务或⼯作单元执⾏完毕之前,其所访问的数据不能受系统其他部分的影响。
当我们编写了⼀条 update 语句,提交到数据库的⼀刹那间,有可能别⼈也提交了⼀条 delete 语句到数据库中。
也许我们都是对同⼀条记录进⾏操作,可以想象,如果不稍加控制,就会出⼤⿇烦来。
我们必须保证数据库操作之间是“隔离”的(线程之间有时也要做到隔离),彼此之间没有任何⼲扰。
4. 持久性(Durability)持久性表⽰在某个事务的执⾏过程中,对数据所作的所有改动都必须在事务成功结束前保存⾄某种物理存储设备。