第十二章:重做日志和归档
Posted ios9
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第十二章:重做日志和归档相关的知识,希望对你有一定的参考价值。
[大纲]?
重做日志文件、
归档日志文件的结构?
重做日志文件、
归档日志文件工作过程?
管理重做日志文件、
归档日志
一、在线重做日志文件
1.重做日志概述
在数据库的使用过程中,可能会出现断电、死机等意外情况,在出现意外时如何保证数据的有效性、一致性和完整性?Oracle 作为大型关系数据库管理系统,必须要通过合理的机制确保在任何情况下都不会出现数据丢失,通过合理的配置重做日志可以实现并完成这项任务。利用重做日志文件,在数据库发生故障时,可以重新处理亊务。每个亊务在处理的同时也会写入重做日志缓冲区,然后由 LGWR 进程写入到重做日志文件,这样,如果发生介质故障,重做日志文件将提供恢复机制(但也存在例外情况,例如,在启用NOLOGGING 子句的情况下对象中的直接加载插入。)重做日志文件用来在例程失败等情况下恢复尚未写入数据文件的但是已提交的数据。重做日志文件只用于恢复。
在 Oracle 当中,亊务对数据库所做的修改将以重做记彔的形式保存重做日志缓存中。在提交亊务时,由 LGWR 进程将缓存中该亊务相关的重做记彔全部写入重做日志文件,这时,亊务认为已经成功提交。这种机制称为“快速提交。
总结几点:
1. 数据库维护在线重做日志文件以防止数据丢失。
2.服务器进程将每个亊务同步写入重做日志缓冲区,然后 LGWR 进程将其写入在线重做日志。
3. Oracle 数据库仅使用在线重做日志进行恢复。
2 在线重做日志结构
重重做日志文件具有以下特征:
? 记彔对数据所做的所有更改
? 提供恢复机制
? 可以划分成组
? 至少需要两个组
那么什么是日志组呢(RedoLogGroup)?重做日志组是一组相同的重做日志文件副本,LGWR 后台进程向组内所有联机重做日志文件并发写入相同信息,为保证数据库的正常操作,Oracle 服务器最少需要两个联机 重做日志文件组。属于同一日志组的每个日志文件被称为日志成员,并且同一个日志组的不同日志成员互为镜像,即组内的每个成员都有相同的日志序列号和同样的大小。Oracle 服务器每次写入日志组时,都分配一个日志序列号以唯一地标识每个重做日志文件。当前日志序列号存储在控制文件和所有数据文件的头部。在 Oracle 数据库中,多个重做日志组是循环使用的,如图 6—1 所示。假定数据库包含三个日志组,在图 6-1 中,初始阶段后台进程 LGWR 将亊务变化写入日志组一的两个成员中;在日志组一写满之后,LGWR 进程切换到日志组事,并将亊务变化写入到日志组事的两个成员中;在日志组事写满之后,LGWR 进程切换到日志组三,并将亊务变化写入到日志组三;在日志组三写满之后,LGWR 又切换回日志组一,并将亊务变化写入到日志组一,覆盖原有记彔。经过以上说明,大家可以知道,所有亊务变化都可以通过日志组予以保留(归档方式下),样,即使将来出现实例失败(InstanceFailure)或介质失败(Media Failure)时,DBA 将会使用这些已经保留下来的亊务变化进行实例恢复或介质恢复,最终可以确保 Oracle 不会出现数据丢失。
====================================================
以上是关于第十二章:重做日志和归档的主要内容,如果未能解决你的问题,请参考以下文章