oracle 归档日志原理,[转载]oracle恢复原理(3)--联机日志和归档日志

本文详细介绍了Oracle数据库的归档日志和联机日志的原理,包括日志内容、日志线程和日志写操作。日志内容主要由改动向量和Redo记录组成,用于记录数据库的改动。日志线程在单实例和RAC环境中有所不同,每个实例有自己的Redo Thread。日志写操作涉及到Log Switch、Checkpoint以及Incremental Checkpoint算法,确保数据一致性。在归档模式下,归档日志对于数据库恢复至关重要。
摘要由CSDN通过智能技术生成

一:日志

Oracle数据库的日志包括联机日志和归档日志。所有的Oracle数据库都需要有联机日志,而且至少要有两组联机日志。而归档日志只有使用归档模式时才会需要,生产数据库必须运行在归档模式。联机日志循环使用,当一组联机日志写满后,就要切换到另一组联机日志,后者的内容就被覆盖,这个过程叫作日志切换(Log

Switch),在日志切换时会触发检查点(Checkpoint),如果数据库是归档模式,还必须完成日志的归档操作。

(一) 日志内容

Redo日志中记录了数据库的改动情况,下面就来看Oracle使用哪些数据结构来记录改动的。

1.改动向量(Change Vector)

改动向量描述对数据库中任何一个数据块所做的一次改动。具体由3个内容组成:

数据本身的改变;

对应的UNDO的改变;

Undo Segment的改变。

比如,要修改Employee表中某个用户的工资,那么修改之前的数据就保存在UNDO中,为了申请事务,还需要修改Undo

Segment段头事务表的信息,这3个就构成了一个Change Vector。

改动向量中的信息包含版本号、事务操作代码以及改动的数据块地址。在建立向量时,会从数据块中复制版本号,在恢复期间,Oracle会读取向量并将改动应用于对应的数据块,同时对数据块的版本号加1。

2.Redo记录

Redo记录由一组改动向量组成,用于描述对于数据库的一个"原子"改动(或者说一个事务)。比如一个最简单的Update操作可能涉及多个数据块内容的改变࿰

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值