一、联机重做日志的规划管理

 1.联机重做日志   

记录了数据的所有变化(DML,DDL或管理员对数据所作的结构性更改等)

提供恢复机制(对于意外删除或宕机利用日志文件实现数据恢复)

可以被分组管理

    11g默认的大小是50M

 2.联机重做日志组

由一个或多个相同的联机日志文件组成一个联机重做日志组

至少两个日志组,每组一个成员(建议每组两个成员,分散放开到不同的磁盘)

由LGWR后台进程同时将日志内容写入到一个组的所有成员

LGWR的触发条件

在事务提交的时候(COMMIT)

Redo Log Buffer 三分之一满

Redo Log Buffer 多于一兆的变化记录

在DBWn写入数据文件之前

     每3秒钟

3.联机重做日志成员

重做日志组内的每一个联机日志文件称为一个成员

一个组内的每一个成员具有相同的日志序列号(log sequence number),且成员的大小相同

每次日志切换时,Oracle服务器分配一个新的LSN号给即将写入日志的日志文件组

LSN号用于唯一区分每一个联机日志组和归档日志

处于归档模式的联机日志,LSN号在归档时也被写入到归档日志之中

4.日志文件的工作方式

日志文件采用按顺序循环写的方式

当一组联机日志组写满,LGWR则将日志写入到下一组,当最后一组写满则从第一组开始写入

写入下一组的过程称为日志切换

切换时发生检查点过程

检查点的信息同时写入到控制文件

5.日志切换和检查点切换

ALTER SYSTEM SWITCH LOGFILE;   --强制产生重做日志切换

ALTER SYSTEM CHECKPOINT;       --强制产生检查点

强制设置检查点间隔(单位为秒)

ALTER SYSTEM SET FAST_START_MTTR_TARGET = 900

        这个参数的含义是是实例恢复时间不会超过900s

6.添加日志文件组

 alter database add logfile
('/u01/app/oracle/oradata/orcl/redo4a.log',
'/u01/app/oracle/oradata/orcl/redo4b.log')
size 50M;

7. 删除日志文件组

       一个实例至少需要两个联机日志文件组

活动或当前的日志组不能被删除

组内成员状态有NULL 值或INVALID状态并存,组不可删除

日志组被删除后,物理文件需要手动删除(对于非OMF)

SQL> ALTER DATABASE DROP LOGFILE GROUP ;
SQL> host rm /u01/app/oracle/oradata/orcl/redo4*

8.添加日志成员

 alter database add logfile member
'/u01/app/oracle/oradata/orcl/redo1b.log' to group ,
'/u01/app/oracle/oradata/orcl/redo2b.log' to group ;

9.删除日志组成员

        不能删除组内的唯一一个成员

不能删除处于active 和current 状态组内的成员

删除处于active 和current 状态组内的成员,应使用日志切换使其处于INACTIVE状态后再删除

对于组内如果一个成员为NULL 值,一个为INVALID,且组处入INACTIVE,仅能删除INVALID状态成员

删除日志成员,物理文件并没有真正删除,需要手动删除

删除日志文件后,控制文件被更新

对于处于归档模式下的数据库,删除成员时确保日志已被归档,查看v$log视图获得归档信息

SQL>  ALTER DATABASE DROP LOGFILE MEMBER '/u01/app/oracle/oradata/orcl/redo2b.log';
SQL> host rm '/u01/app/oracle/oradata/orcl/redo2b.log'

10.日志的重定位及重命名

所需权限

ALTER DATABASE 系统权限

复制文件到目的位置操作系统权限(写权限)

CURRENT状态组内的成员不能被重命名

建议该行为之前备份数据库

重命名或重定位之后建议立即备份控制文件

重定位及重命名的两种方法

1.添加一个新成员到日志组,然后删除一个旧的成员

2.使用ALTER DATABASE RENAME FILE 命令(不区分归档与非归档模式)

复制联机日志文件到新路径:ho cp <oldfile> <newfile>

执行ALTER DATABASE RENAME FILE '<oldfile>' TO '<newfile>'

对于处于CURRENT状态的需要改名且不切换的情况下

办法是切换到MOUNT状态下再执行上述操作

 11. 清空日志组

   清除日志后,日志序列号将会变为0,所以应该尽快做一个全备份,因为oracle进行数据库恢复时要求重做日志序列号是连续的。

    ALTER DATABASE CLEAR LOGIFLE GROUP n

ALTER DATABASE CLEAR UNARCHIVED LOGFILE GROUP n --使用unarchived 避免归档

12. 与日志有关的动态性能视图 

V$LOG

V$LOG中STATUS的状态值

UNUSED: 从未对该联机日志写入任何内容,一般为新增加联机日志文件或是使用resetlog后的状态

CURRENT:当前重做日志文件,表示该重做日志文件为活动状态,能够被打开和关闭

ACTIVE:处于活动状态,不属于当前日志,崩溃恢复需要该状态,可用于块恢复,可能归档,也可能未归档

CLEARING:表示在执行alter database clear logfile命令后正将该日志重建为一个空日志,重建后状态变为unused

CLEARING_CURRENT:当前日志处于关闭线程的清除状态。如日志某些故障或写入新日志标头时发生I/O错误

INACTIVE:实例恢复不在需要联机重做文件日志组,可能归档也可能未归档

V$LOGFILE

V$LOGFILE中STATUS的状态值

INVALID :表明该文件不可访问

STALE :表明文件内容不完全

DELETED : 表明该文件不再使用

NULL :表明文件正在使用

v$log_history

  可以回去重做日志切换的时间及间隔,一般将重做日志文件的切换间隔在20~30分钟,这对多数数据库系统都是可以接受的。

二、演示

查看当前数据的日志

 SQL> select group#,sequence#,members,bytes// MB,status,archived from v$log;

    GROUP#  SEQUENCE#     MEMBERS     MB     STATUS       ARCHIVED
---------- ---------- ---------- ---------- ---------------- -------
        INACTIVE   YES
        CURRENT   NO
        INACTIVE   YES
SQL> col member for a55
SQL> set line 120
SQL> select * from v$logfile; GROUP# STATUS TYPE MEMBER IS_
---------- ------- ---------- ------------------------------------------------------- ---
3 ONLINE /u01/app/oracle/oradata/orcl/redo03.log NO
2 ONLINE /u01/app/oracle/oradata/orcl/redo02.log NO
1 ONLINE /u01/app/oracle/oradata/orcl/redo01.log NO

添加日志组

SQL> alter database add logfile
2 ('/u01/orcl/onlinelog/redo4a.log',
3 '/u02/orcl/onlinelog/redo4b.log',
4 '/u03/orcl/onlinelog/redo4c.log')
5 size 50M; 数据库已更改。

查看日志组

SQL> select group#,sequence#,members,bytes/1024/1024 MB,status,archived from v$log;

    GROUP#  SEQUENCE#     MEMBERS     MB STATUS         ARC
---------- ---------- ---------- ---------- ---------------- ---
1 25 1 50 INACTIVE YES
2 26 1 50 CURRENT  NO
3 24 1 50 INACTIVE YES
4 0 3 50 UNUSED YES

删除非当前日志组

SQL> alter database drop logfile group 1;

数据库已更改。

删除当前日志组

当日志组变为inactive时才可以删除

SQL> alter system switch logfile;

系统已更改。
SQL> alter system checkpoint; 系统已更改。
###检查状态是否变为inactive
SQL> alter database drop logfile group 2;

添加日志组成员

alter database add logfile member '/u01/orcl/onlinelog/redo2d.log' to group 2;

删除日志组成员

alter database drop logfile member '/u01/orcl/onlinelog/redo2d.log';

Oracle重做日志文件的更多相关文章

  1. oracle重做日志文件硬盘坏掉解决方法

    rman target/ list backup; list backup summary; 删除数据库数据文件夹下的log日志,例如/u01/app/oracle/oradata/ORCL下的所有后 ...

  2. 初识oracle重做日志文件

    转自 http://blog.csdn.net/indexman/article/details/7746948 以下易容翻译自oracle dba官方文档,不足之处还望指出. 管理重做日志文件 学习 ...

  3. ORACLE - 管理重做日志文件

    ORACLE重做日志文件用于在数据库崩溃等情况下用于恢复数据,默认情况下为三个文件redo01.log/redo02.log/redo03.log,文件组循环使用,在录入与更新操作比较多的应用中,日志 ...

  4. ORACLE 移动数据文件 控制文件 重做日志文件

    ORACLE数据库有时候需要对存储进行调整,增加分区.IO调优等等,此时需要移动数据文件.重做日志文件.控制文件等等,下文结合例子总结一下这方面的知识点. 进行数据文件.重做日志文件.控制文件的迁移前 ...

  5. Oracle 联机重做日志文件(ONLINE LOG FILE)

    --========================================= -- Oracle 联机重做日志文件(ONLINE LOG FILE) --================== ...

  6. oracle redo 重做日志文件

    以下易容翻译自oracle dba官方文档,不足之处还望指出. 管理重做日志文件 学习目标:1.解释重做日志文件的目的2.描述重做日志文件的结构3.学会控制日志切换与检查点4.多元化管理重做日志文件5 ...

  7. ORACLE告警日志文件

    告警日志介绍 告警日志文件是一类特殊的跟踪文件(trace file).告警日志文件命名一般为alert_<SID>.log,其中SID为ORACLE数据库实例名称.数据库告警日志是按时间 ...

  8. Oracle重做日志恢复数据模拟实验

    一 系统环境: 1.操作系统:oracle Linux 5.6 2.数据库: Oracle 11g 二 Oracle 重做日志的作用: [模拟介质恢复] 1. 关闭数据库归档模式: [oracle@t ...

  9. oracle redo日志文件损坏恢复

    参考:How to Recover from Loss Of Online Redo Log And ORA-312 And ORA-313 (Doc ID 117481.1) 在线重做日志文件丢失后 ...

随机推荐

  1. Git的常用操作

    $ git log //查看commit记录 $ git add <file> //添加文件到commit中 .代表所有改动的文件 $ git commit -m 'meesage' // ...

  2. 四个使用promise的语句之间的不同点在哪儿?

    http://jsbin.com/tuqukakawo/1/edit?js,console,output #1 doSomething().then(function () { return doSo ...

  3. ajax同步、异步执行简单理解与证明

    此理解范例代码来自前几篇随笔! 首先我们来先了解下AJAX: Ajax:全称“Asynchronous Javascript and XML”(异步Javascript和XML),他是由Javascr ...

  4. LeetCode Reverse Words in a String II

    原题链接在这里:https://leetcode.com/problems/reverse-words-in-a-string-ii/ 题目: Given an input string, rever ...

  5. tableView和scrollView滚动起冲突

    tableView和scrollView滚动起冲突 tableView也是继承的scrollView,所以在滚动的时候也会触发scrollView的代理方法,在scrollViewDidScroll中 ...

  6. 修改easyui中datagrid表头和数据不能分开对齐的BUG。

    easyui的datagrid中表头和列只能同时全部向左对齐,全部向右对齐或者居中对齐. 有时候有需求,数据向左或向右,表头居中对齐. 在不修改源码的情况下.下面的代码可以实现该功能. 把下面代码放在 ...

  7. Maven聚合与继承的实例讲解(二)

    继续上一节讲Maven的内容,我们这个节继续讲Maven继承和聚合的其他内容.    现在我们新建一个实例来测试Maven有关于聚合的部分     测试开始 一.建立以pom为packaging的项目 ...

  8. PostgreSQL中数据库,表,等对象的oid与对象名的对应关系

    -bash-4.1$ oid2name Password: All databases: Oid Database Name Tablespace--------------------------- ...

  9. [原创]java WEB学习笔记94:Hibernate学习之路---session 的管理,Session 对象的生命周期与本地线程绑定

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  10. OpenWrt——神奇的路由系统

    鉴于最近大家对这个系统比较感兴趣而且疑问很多所以本渣就整理下我对这个系统的理解和最实用的802.1x认证的理解.还望大家多多互相交流. 如果您时间紧张直接看最后的步骤,时间充裕的请仔细阅读,理解. O ...