Oracle重做日志组状态及切换解析

发布时间:2020-04-29 13:04:10 作者:sunhuabin2016
来源:网络 阅读:1232

     Oracle重做日志(redo log)是用来记录操作条目,用于数据库数据恢复。为了提高效率,oracle通常建议设置三组redo log。


一.概述

oracle重做日志组通常有四种状态,即unused,inactive,active,current。

unused通常指从未被使用的日志组,即新添加的日志组。

current状态为LGWR进程正把redo log buffer的日志写进日志组中。

active为刚刚完成日志切换后的状态,此时该日志组中提交的事务引起的数据改变还没有完全从DB buffer cache写入到数据文件中,因此该日志组还不能被覆盖,并且待完全写入后变为inactive状态。如果数据库为归档模式,那么是在该状态下完成归档的。

inactive状态的日志可以被覆盖,可以允许写入日志。如果是在归档模式下,那么此阶段证明归档已经完成。

二.实验

本次实验以开启归档模式为例:

日志组为三组,状态分别为inactive,inactive,current。如图:

Oracle重做日志组状态及切换解析

手动归档后,观察发现组1的状态变为current,组3的状态变为active,组2的状态不变 。如下图:

Oracle重做日志组状态及切换解析

说明当前写入的日志组为组1,组3正在进行归档和进行必要的数据写入至datafile。待这两项工作完成后,再看如下图:

Oracle重做日志组状态及切换解析

说明组3已经完成了归档,可以允许下一次写入了。在非归档模式下,组3的状态也能变成inactive,说明完成了数据从DB BUFFER CACHE写入至DB files。

三、总结

上述实验很好的说明了oracle日志组在整个生命周期所具有的状态。当然没有看到unused状态,这种状态是当日志组刚新添到数据库后的状态,这种操作在生产环境中很少,所以本次实验没有看到这种状态。

另外有人会认为在手动日志切换时为什么使用命令alter system archive log current。这里也做一个说明。

两组命令最后的效果一样。alter system switch logfile是不等归档完成就进行switch logfile操作,速度快,尤其在非归档模式下适用,对当前实例生效。而alter system archive log current要等待归档完成才操作,对所有实例生效。


推荐阅读:
  1. 修改oracle重做日志文件大小
  2. Oracle的重做日志

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

group logfile acle

上一篇:mysql之数据备份还原

下一篇:OCLint+Xcode实现Code Review

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》