日志文件分类:重做日志文件

归档日志文件

警告日志文件

跟踪日志文件

redo_log_file文件作用:

1)维护数据一致性

2)记录了数据库里的更改操作

redo_log_friles以组为单位,一个组下可以有多个成员,顺序循环写,一个数据库要启动至少要有2个日志组,每个组下至少有一个成员,redolog以多工方式工作。

日志切换:从一个组切换到下一个组的过程。

1)自动切换

2)手工切换

规划redo_log_file日志:

分散到不同磁盘,磁盘io要够用,io读写都要快。

日志大小问题:要满足数据库自动切换日志的时间间隔在15--20min左右。

1)查询日志文件位置:

SQL>select * from v$logfile;

GROUP# STATUS  TYPE    MEMBER                                  IS_

---------- ------- ------- ---------------------------------------- ---

1 STALE   ONLINE  /u01/oracle/oradata/rezin/redo01.log     NO

2 STALE   ONLINE  /u01/oracle/oradata/rezin/redo02.log     NO

3        ONLINE  /u01/oracle/oradata/rezin/redo03.log     NO

SQL> select * from v$log;

GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS

---------- ---------- ---------- ---------- ---------- --- ----------------

FIRST_CHANGE# FIRST_TIME

------------- -------

1          1         37   52428800          1 YES INACTIVE

642652 16-3? -15

2          1         38   52428800          1 YES INACTIVE

668961 16-3? -15

3          1         39   52428800          1 NO  CURRENT

695725 17-3? -15

日志状态:status常见值

unused:表示从未对联机重做日志文件组进行写入,这是刚添加联机重做日志组状态。

current:表示当前正在使用的联机重做日志文件组。

active:表示联机重做日志文件组是活动的,但不是当前正在使用的。崩溃恢复需要该状态,可能归档,也可能没有归档。

clearing:表示执行alter database clear logfile后正在将该日志重建一个空日志,日志清除后,状态为unused。

手工切换日志:

SQL>alter system switch logfile;

添加日志组文件:

         语法:alter database add logfile [group n1] ('<dir>','<dir>',....) size N,[group n2] ('<dir>','<dir>') size N,.........;

SQL> alter database add logfile group 4 '/u01/oracle/oradata/orcl/redo04.log' size 50m;

Database altered.

SQL> alter database add logfile '/u01/oracle/oradata/orcl/redo05.log' size 50m;

Database altered.

添加组指定多个成员:

SQL> alter database add logfile

('/u01/oracle/oradata/orcl/redo07.log','/u01/oracle/oradata/orcl/redo08.log') size 50m;

Database altered.

SQL> alter database add logfile group 7

('/u01/oracle/oradata/orcl/redo09.log','/u01/oracle/oradata/orcl/redo10.log') size 50m;

Database altered.

一条语句添加多个日志组:

SQL> alter database add logfile group 7 '/u01/oracle/oradata/orcl/redo11.log' size 50m,group 8 '/u01/oracle/oradata/orcl/redo12.log' size 50m;

Database altered.

添加日志组成员:

SQL>alter database add member '<dir1>' to group N, '<dir1>' to group N;

SQL> alter database add logfile member '/u01/oracle/oradata/orcl/redo13.log' to group 8;

Database altered.

给多个组添加成员:

SQL> alter database add logfile member '/u01/oracle/oradata/rezin/redo014.log' to group 1,'/u01/oracle/oradata/rezin/redo015.log' to group 2;

invalid:要么日志文件不存在,要么是新添加的成员而另一个为用过的成员。

删除日志组:alter database drop logfile group n1,group n2;

日志状态为active、current状态的不能删除,需要手工切换日志直到可以删除为止。

SQL>alter database drop logfile group 9;

SQL>alter database drop logfile group 5,group 6;

删除成员指令: alter database drop logfile member '<dir1>','<dir2>';

SQL>alter database drop logfile member '/u01/oracle/oradata/orcl/redo07.log';

SQL>alter database drop logfile member

'/u01/oracle/oradata/orcl/redo01.log', '/u01/oracle/oradata/orcl/redo02.log';

附加:删不掉切换日志。

日志重命名:相当于更改路径,只有current不可以重命名。

语法:#cp <oldfile> <newfile>

SQL>alter database rename file '<oldfilename>' to '<newfilename>';

SQL> ho cp /u01/oracle/oradata/orcl/redo11.log /u01/oracle/oradata/rezin/redo11.log

SQL> ho ls /u01/oracle/oradata/rezin/redo11.log

/u01/oracle/oradata/rezin/redo11.log

SQL> alter database rename file '/u01/oracle/oradata/orcl/redo11.log' to

'/u01/oracle/oradata/rezin/redo11.log';

联机重做日志文件重命名:不能是current,只能oracle在mount和open状态使用。

语法:alter database rename file '<oldfilename>' to '<newoldfile>';

数据库的状态监控:

状态:inactive(循环之外),active,current(循环之内)

监控:select 'ho ls '||member from v$logfile;

'HOLS'||MEMBER

--------------------------------------------------------------------------------

ho ls /u01/oracle/oradata/rezin/redo01.log

ho ls /u01/oracle/oradata/rezin/redo02.log

ho ls /u01/oracle/oradata/rezin/redo03.log

查询在不在:

SQL> ho ls /u01/oracle/oradata/rezin/redo01.log

/u01/oracle/oradata/rezin/redo01.log

查看磁盘空间够不够用:

[oracle]#dh -f

日志切换间隔时间:查看时间间隔是否在15到20分钟之间。

SQL> select group#,to_char(first_time,'yyyy-mm-dd hh24:mi:ss') as first_time from v$log;

GROUP# FIRST_TIME

---------- --------------------------------------------------------------

1 2015-03-17 08:54:07

2 2015-03-17 08:53:10

3 2015-03-17 08:53:22

4 2015-03-17 10:41:49

5 2015-03-17 15:07:24

6 2015-03-17 16:12:48

日志组下必须有多个成员,不是多个成员组,修改成多个成员组。

修改日志文件大小:先删掉已有日志组及其物理文件,然后再重新建立组并修改成相应大小即可。

联机重做日志异常(日志不一致、丢失、损坏)处理:

1)日志文件不一致:清空不一致日志组,oracle数据库一致性关闭的可以在启动时清空日志文件。

SQL> alter database clear logfile group n;  --->inactive可清空

SQL> alter database clear unarchived logfile group n;   ---->active可清空

2)日志文件丢失:

方法一:数据库一致性关闭的,如果日志文件丢失可以通过清空日志文件的办法恢复,步骤同上。

方法二:数据库非一致性关闭

1)加隐藏参数:同control_file里的_allow_resetlog_corruption隐藏参数解决问题。

2)如果归档模式可以通过recover指令恢复:欺骗的手段

sql>recover database using backup controlfile;

sql>alter database open resetlogs;

3)非归档模式下,加隐藏参数忽略数据库一致性,可以起到很大的作用,但不支持使用。

Oracle体系结构之联机日志文件管理的更多相关文章

  1. Oracle基础 05 联机日志 redolog

    --两个相关视图v$logv$logfile alter system switch logfile;  --强制日志切换alter system checkpoint;      --强制检查点 - ...

  2. Oracle数据库体系结构(6)数据库归档重做日志文件管理

    归档重做日志文件的概念和选择 Oracle数据库能够把已经写满了的重做日志文件保存到一个或多个指定的离线位置,这种保存的文件为归档重做日志文件.通常情况下一个归档重做日志时一个被LGWR写满的重做日志 ...

  3. Oracle调整联机日志大小

    近期一个项目反馈月底高峰期时系统整体性能下降,抓取对应的AWR和ASH查看,等待事件排第一位的竟然是redo日志切换.进一步看每秒的日志量是5M多,而日志文件大小仅有200M.建议项目上调整日志大小, ...

  4. Oracle日志文件管理与查看

    Oracle日志文件管理与查看 from:http://hi.baidu.com/shuker/item/25ee611ee960c7426826bb1f 1.查询系统使用的是哪一组日志文件: sel ...

  5. Oracle联机日志损坏解决办法

    关于此问题,在网上找到一篇不错的文章. 大家都清楚,联机日志分为当前联机日志和非当前联机日志. ---------------------------------------------------- ...

  6. ORACLE联机日志文件丢失或损坏的处理方法(转)

    经验总结: 联机日志分为当前联机日志和非当前联机日志,非当前联机日志的损坏是比较简单的,一般通过clear命令就可以解决问题. 损坏非当前联机日志:1.启动数据库,遇到ORA-00312 or ORA ...

  7. ORACLE体系结构一 (物理结构)- 数据文件、日志文件、控制文件和参数文件

    一.物理结构Oracle物理结构包含了数据文件.日志文件.控制文件和参数文件 1.数据文件每一个ORACLE数据库有一个或多个物理的数据文件(data file).一个数据库的数据文件包含全部数据库数 ...

  8. Oracle实例和Oracle数据库(Oracle体系结构)

    --========================================== --Oracle实例和Oracle数据库(Oracle体系结构) --==================== ...

  9. 【转载】Oracle实例和Oracle数据库(Oracle体系结构)

    免责声明:     本文转自网络文章,转载此文章仅为个人收藏,分享知识,如有侵权,请联系博主进行删除.     原文作者:Leshami      原文地址:http://blog.csdn.net/ ...

随机推荐

  1. 常用CSS备忘

    1 怎样让div中的img居中 水平居中:div设置:text-align:center; img设置:width:图片宽度; margin:0 auto; 垂直居中:div设置:position:r ...

  2. SpringMVC -- 梗概--源码--贰--RestFul收参(了解) @PathVariable

    1>定制方式: //如下两个路径都可以访问到如下方法,请求路径不同,则name61和pwd61匹配到的值不同 //http://localhost:8989/appname/ful/lime/1 ...

  3. 7 -- Spring的基本用法 -- 6... Spring 3.0 提供的Java配置管理

    7.6 Spring 3.0 提供的Java配置管理 Spring 允许使用Java类进行配置管理,可以不使用XML来管理Bean,以及Bean之间的依赖关系. Interface :Person p ...

  4. swift--CATransform3D的简单介绍

    今天来了解下CATransform3D的一些基本的知识.CATransform3D是一个用于处理3D形变的类,其可以改变控件的平移.缩放.旋转.斜交等,其坐标系统采用的是三维坐标系,即向右为x轴正方向 ...

  5. Window日志分析

    0X00 简介 0x01 基本设置 A.Windows审核策略设置 前提:开启审核策略,若日后系统出现故障.安全事故则可以查看系统的日志文件,排除故障,追查入侵者的信息等. 打开设置窗口 Window ...

  6. Memcached 数据导出与导入

    我们使用 memcached-tool 命令来导出数据: [root@localhost ~]# memcached-tool dump > /tmp/.txt Dumping memcache ...

  7. mac 常用的终端命令

    OSX 的文件系统 OSX 采用的Unix文件系统,所有文件都挂在跟目录 / 下面,所以不在要有Windows 下的盘符概念. 你在桌面上看到的硬盘都挂在 /Volumes 下. 比如接上个叫做 US ...

  8. Excel 导入遍历

    package com.founder.ec.cms.service.impl; import com.founder.ec.cms.service.ProductListImportService; ...

  9. React Native(四)——顶部以及底部导航栏实现方式

    效果图: 一步一步慢慢来: 其实刚入手做app的时候,就应该做出简单的顶部以及底部导航栏.无奈又在忙其他事情,导致这些现在才整理出来. 1.顶部导航栏:react-native-scrollable- ...

  10. .net页面生命周期【转】

    .Net 页面生命周期IIS 所收到的对某 Microsoft ASP.NET 页面的每个请求都被移交给 ASP.NET HTTP 管线.HTTP 管线由一系列托管对象组成,这些对象按顺序处理该请求, ...