- 1、本文档共31页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Oracle数据库备份与恢复(理论)
Oracle数据库备份与恢复 引言 Oracle作为数据库的工业标准,在企业界得到了广泛的应用。为避免数据丢失和数据库失效对企业的影响,必须保持数据库的完整性和可用性。数据库管理员DBA的主要职责之一就是备份数据库和在数据库发生故障时高效、安全地恢复数据库。 备份就是把数据库复制到磁带、磁盘等存储设备的过程,以供故障发生时执行数据库恢复。 数据库常见故障类型 事务内部故障 系统故障 介质故障 计算机病毒 Oracle数据库保护机制 数据库备份 事务日志 数据库的事务日志是一组操作系统文件,它记录了提交事务所做的数据库修改。当提交事务时,在修改数据库之前,Oracle在事务日志中写入足够的信息,如果数据库需要恢复,可以使用这些信息重做事务(包括UNDO和REDO)。 数据库恢复 恢复可以分为完全恢复和不完全恢复 完全数据库恢复是恢复到故障发生前的状态,所有已经提交的操作都进行恢复,确保数据库不丢失任何数据,完全恢复只用于归档模式。 不完全数据库恢复是将数据库恢复到备份点与介质失败点之间某个时刻的状态,并不是恢复所有提交的操作,不完全恢复可能丢失部分数据。 任何类型的恢复包括两个阶段:前滚阶段和回滚(回退)阶段。 前滚阶段 在前滚恢复阶段(roll-forward recovery),恢复管理器应用必要的事务日志组“重做”(REDO)所有提交的不在数据库数据文件中的事务 。 回滚阶段 在前滚恢复后,Oracle必须执行回滚恢复(roll-back recovery)。 由于一些未完成的事务对数据库的修改信息已经提交到数据库,为保证数据库的一致性,需要清除这些事务对数据库的修改,数据库应执行回滚操作(UNDO),强制撤销这些未完成事务。 前滚和回滚的执行除了管理员或应用程序调用外,执行前滚操纵还是回滚操作与检查点的出现相关 恢复数据库所使用的结构 数据库备份 当介质故障时进行数据库恢复,利用备份文件恢复损坏的数据文件或控制文件。 日志 每一个Oracle数据库实例的日志记录了数据库所作的全部修改。 回退段 回退段用于存储正在进行的事务(未提交的事务)所修改数据的老数据,该信息在数据库恢复过程中用于撤销任何非提交的修改。 控制文件 一般用于存储数据库的物理结构的状态,控制文件中的某些状态信息在实例恢复和介质恢复期间用于引导Oracle。 不完全恢复 Oracle和恢复管理器支持三种不同类型的不完全恢复 基于时间(TIME)的恢复 基于时间的恢复也叫时间点恢复,它将数据库中提交事务的工作恢复到一个特定的时间点为止。 基于修改(SCN)的恢复 基于修改的恢复是将数据库中提交事务的工作恢复到一个特点的系统修改序列号SCN为止,Oracle为每个提交事务分配了一个唯一的SCN。一般来说,如果知道数据库恢复的最后一个事务的SCN,那么可以执行基于修改的恢复。 基于取消的恢复。 基于取消(CANCEL)的恢复是将数据库中提交的事务恢复到一个特定日志组。 事务与并发 事务 事务(transaction)是数据库的逻辑工作单元,是用户定义的一组操作序列,如一组SQL语句,一条SQL语句或整个程序。通常情况下,一个应用程序包括多个事务。在SQL中,定义事务,以Begin开始,以Commit或Rollback结束。 事务开始BEGIN 处理 IF 成功 提交COMMIT ELSE 回滚ROLLBACK 事务属性 (1)原子性:事务是数据库最小的工作单元,是不可分的。事务中的操作要么都做,要么都不做。 (2)一致性:事务执行前后,数据库都应处于数据一致的状态。当数据库只包含成功提交事务的结果时,我们就说数据库处于一致性状态。 (3)隔离性:尽管多个事务可以并发,但相互不干扰,隔离性要求事务不查看其他事务的中间阶段。 (4)持久性:事务成功完成后,对数据库的改变必须是持久的。事务成功执行后系统故障,应能恢复对数据库的更改(Undo),如果事务执行时系统出现故障,应该允许系统在重新启动后完成未完成的事务操作(Redo),保证事务的完整性,事务是一个执行单元,也是一个恢复单元。 并发现象 并发操作如果不进行适当的控制,可能导致数据库中数据的不一致性。 并发操作带来的不一致性包括四类:丢失更新、读脏数据、不可重复读和幻像读。 四个隔离级别 未提交读发生(read uncommitted):读取数据时,不发出共享锁,也不接受排它锁,出现读脏数据。 提交读(read committed):读取数据时,使用共享锁,在该级别上,不会出现读脏数据。 可重复读(repeateable read):持有锁直到事务结束。不会出现读脏数据和不可重复读。 可序列化(serializable):防止其
文档评论(0)