千家信息网

Online Redo Log File(联机重做日志)

发表于:2024-10-16 作者:千家信息网编辑
千家信息网最后更新 2024年10月16日,Online Redo Log File(联机重做日志)一.Online Redo Log File作用1.记录对数据所做的所有更改。2.提供恢复机制。二.Redo Log File Groups(联
千家信息网最后更新 2024年10月16日Online Redo Log File(联机重做日志)

Online Redo Log File(联机重做日志)

一.Online Redo Log File作用

1.记录对数据所做的所有更改。

2.提供恢复机制。


二.Redo Log File Groups(联机重做日志组)

Oracle把Redo Log Files划分不同的组,要正常运行Oracle至少需要两个组,所以Oracle至少要有两个联机重做日志,而同一组的Redo Log File文件内容是一样的,由LGWR后台进程负责把相关信息写入Redo Log File(由于LGWR是对同组的所有Log文件进行写操作,所以同组的Log文件的内容都是一致的),而Redo Log File中的每条记录(entries)都有一个Log sequence numbers(LSN:相当于一个流水号)。


三.Online Redo Log File相关

1.Online Redo Log File是以循环方式使用的(一旦某个重做日志文件被写满,LGWR就会切换到下一个日志组)。

2.LGWR会在以下情况下进行写Redo Log File文件:

(1).当提交事务处理时(Transaction commit)。

(2).每3秒钟写一次。

(3).当重做日志缓冲区(Redo Log Buffer )被写满三分之一时。

(4).当重做日志缓冲区(Redo Log Buffer )内的已更改记录超过1MB时。

(5).在DBWn将数据库缓冲区高速缓存中修改的块写入数据文件之前(写Data file之前)。

3.LGWR在切换日志组时,还会触发:

(1).执行检查点(checkpoint:writing of dirty/mdified block from the buffer cache to disk)操作。

(2).将信息写入控制文件(Control file)。

4.Redo Log File的相关命令

(1).增加Redo Log File Group及其相应Redo Log Files:

alter database add logfile group 3

('$HOME/Oradata/u01/log3a.rdo',

'$HOME/Oradata/u02/log3b.rdo')

复制代码

(2).对某个Group增加Redo Log File文件:

alter database add logfile member

'$HOME/Oradata/u04/log1c.rdo' to group 1,

'$HOME/Oradata/u04/log2c.rdo' to group 2,

'$HOME/Oradata/u04/log3c.rdo' to group 3,

复制代码

(3).删除Redo Log File Member(每个Redo Log File Group中的每个Log文件都称为一个Member)

alter database drop logfile member

'$HOME/Oradata/u04/log3c.rdo';

复制代码

(4).删除Redo Log File Group

alter database drop logfile group 2;

5.Redo Log File建议用".rdo"结尾。

6.可通过动态性能视图(Dynamic Performance View)查询Redo Log File的相关信息。

(1).v$log:Display the redo log fileinformation from the control file.


Select * from v$logfile;


(2).v$logfile:Identifies redo log froups and menbers an menbers status.


select group# ,thread#,sequence#,status from v$log;


7.只有一个Group中还有一个Redo Log File是正常的,Oracle就可以正常运行。这和Control File不同,如果其中一个Control File损坏,Oracle就不能正常运行


0