首页 > 技术文章 > Oracle 归档日志管理

saratearing 2016-11-29 18:13 原文

 一、常用日志查询语句

select * from v$flash_recovery_area_usage; --查看空间占用率,如果 ARCHIVED LOG 超过90%,Oracle随时有宕机的危险

select * from v$recovery_file_dest; --查看归档日志大小及使用情况

select group#, bytes, status from v$log; --查看现有日志

select sequence#,first_time from v$loghist;--列出所有归档redo日志文件的顺序和产生的时间

select * from v$archived_log;  --查看v$archive_log

select count(*) from v$archived_log where archived='YES' and deleted='NO'; --查看所有归档,未删除的归档日志

 二、归档日志管理

Oracle日志分类 
分三大类: Alert log files--警报日志,Trace files--跟踪日志(用户和进程)和  redo log 重做日志(记录数据库的更改)。 

重做日志分为在线重做日志和归档重做日志。 
online Redo log files--在线重做日志,又称联机重做日志,指Oracle以SQL脚本的形式实时记录数据库的数据更新,换句话说,实时保存已执行的SQL脚本到在线日志文件中(按特定的格式)。 
Archive Redo log files--归档重做日志,简称归档日志,指当条件满足时,Oracle将在线重做日志以文件形式保存到硬盘(持久化)。 

重做日志的简单原理:在数据更新操作commit前,将更改的SQL脚本写入重做日志。主要用于数据库的增量备份和增量恢复。  

重做日志直接对应于硬盘的重做日志文件(有在线和归档二种),重做日志文件以组(Group)的形式组织,一个重做日志组包含一个或者多个日志文件。 

关于在线重做日志(online redo log) 

在线重做日志的原理: 
    
     对于在线重做日志,Oracle 11g默认对于每个数据库实例,建立3个在线日志组,每组一个日志文件,文件名称为REDO01.LOG,REDO02.LOG和REDO03.LOG。(用户可以通过视图操作添加/修改/删除日志组和日志文件来自定义在线重做日志) 
     每组内的日志文件的内容完全相同,且保存在不同的位置,用于磁盘日志镜像,以做多次备份提高安全性。默认情况这3组通常只有一组处于活动状态,不断地同步写入已操作的脚本,当日志文件写满时(达到指定的空间配额),如果当前数据库处于归档模式,则将在线日志归档到硬盘,成为归档日志;若当前数据库处于非归档模式,则不进行归档操作,而当前在线日志的内容会被下一次重新写入覆盖而无法保存。因此,通常数据库在运行时,是处于归档模式下的,以保存数据更新的日志。 
    当前归档日志组写满后,Oracle会切换到下一日志组,继续写入,就这样循环切换;当处于归档模式下,切换至原已写满的日志组,若该日志组归档完毕则覆盖写入,若没有则只能使用日志缓冲区,等待归档完毕之后才能覆盖写入。当然,处于非归档模式下是直接覆盖写入的。(关于数据库归档模式的设置,我会在另外的博文中讲到)。 

    Oracle提供了2个视图用于维护在线重做日志:V$LOG 和  V$LOGFILE,我们可以通过这两个视图查看和修改在线日志。    

关于V$LOG视图的详细属性字段可Oracle 11g的官方文档:http://download.oracle.com/docs/cd/B28359_01/server.111/b28320/dynviews_2029.htm 
关于V$LOGFILE视图的详细属性字段可Oracle 11g的官方文档: 
http://download.oracle.com/docs/cd/B28359_01/server.111/b28320/dynviews_2031.htm 

还可以通过ALTER DATABASE ADD 、delete等命令增加/修改/删除在线日志或日志组,具体操作可查看http://blog.csdn.net/robinson_0612/archive/2010/07/20/5749556.aspx 

关于归档重做日志(Archive redo log) 

其实,所谓的归档,就是指将在线日志进行归档、持久化到成固定的文件到硬盘,便于以后的恢复和查询。 当然,前提条件是数据库要处于归档模式。 
    
Oracle 11g 默认是为归档日志设定2个归档位置,这2个归档位置的的归档日志的内容完全一致,但文件名不同。 

 

Oracle数据库开归档之后,oracle 系统默认的归档空间为2G,由于日志过多,空间写满,数据库的redo文件不能归档,而出现oracle数据库挂起的问题。oem打开oracle 10g 数据库操作界面,会显示如下错误信息: 由于输出设备已满或不可用, 归档程序无法归档重做日志。 数据库无法使用

现将解决办法稍作总结:

1、添加新的日志文件

--查看归档日志组和路径信息
SQL>select group#, member from v$logfile;
--添加日志文件
SQL>alter database add logfile group 5'/usr/local/oracle/oradata/greedb/redo05.log' size 2048M; 

-- 查看添加后的组状态:
SQL
> select group#, bytes, status from v$log;
SQL
> select group#, member from v$logfile;

2、增大归档日志空间

查看db_recovery

SQL> show parameter db_recovery
NAME                                   TYPE               VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest                 string       G:\Oracle\product\10.2.0\flash _recovery_area
db_recovery_file_dest_size           big integer   2G

通过以下方法调整系统的回闪恢复区大小:

  • 首先是关闭数据库:以SYS身份链接到oracle,执行shutdown immediate;
  • 启动数据库到mount状态:startup mount
  • 查看回闪恢复区的大小和存放目标:show parameter db_recovery_file_dest
  • 修改回闪恢复区的大小alter system set db_recovery_file_dest_size = 4G(缺省是2G,可以根据实际情况调整大小)
  • 最后打开数据库: alter database open;

OK , 问题解决。数据库恢复使用。

3、清空Oracle日志信息

 在controlfile中记录着每一个archivelog的相关信息,如果只删除OS级别的归档日志,controlfile中仍然记录着这些archivelog的信息,在oracle的OEM管理器中扔有可视化的日志出现,也就是oracle并不知道这些文件已经不存在了。需使用以下方法,彻底删除:

1、连接 RMAN管理 

rman target  /  或者 RMAN target sys/sysadmin@orcl

2、查看归档日志列表

查看归档日志列表:list archivelog all;
查看失效的归档日志列表:list expired archivelog all;

3、删除归档日志

--检查控制文件和实际物理文件的差别
RMAN> crosscheck archivelog all;
--删除当前时间之间的所有归档日志
RMAN>delete archivelog all completed before 'sysdate';  

--删除从7天前到现在的全部日志,慎用!!!
RMAN> delete archivelog from time 'sysdate-7';

--以上操作仍然会在RMAN里留下未管理的归档文件,可使用以下命令删除
delete expired archivelog all;

4、退出RMAN

RMAN> exit
其他RMAN操作
 show all --查看所有的rman策略.

如何确认归档日志是否过期,rman有一个保留策略,可以定义多少天之前的日志算为过期;

CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 14 DAYS;

--以下步骤可不做

5、清空v$archived_log

SQL> execute sys.dbms_backup_restore.resetCfileSection(11);

6、查看v$archive_log

SQL>select * from v$archived_log;

7、生成新的日志文件

SQL>alter system switch logfile;

  三、其他说明

当一组联机重做日志写满时,LGWR进程将开始写下一组日志文件。这被称为日志切换。此时,会产生检查(校验)点操作,还有一些信息被写到控制文件中。除了在重做日志自动切换和自动产生的检查点之外,Oracle数据库dba还可能根据管理和维护的需要,在任何时候强制性的进行重做日志切换,也可以强制性的产生校验点。

强制性产生重做日志文件切换的命令为:

alter system switch logfile  强制性产生校验点,不一定就归档当前的重做日志文件,(若自动归档打开,就归档前的重做日志,若自动归档没有打开,就不归档当前重做日志。)

alter system checkpoint

alter system archive log current 是归档当前的重做日志文件,不管自动归档有没有打都归档。
主要的区别在于:
ALTER SYSTEM SWITCH LOGFILE对单实例数据库或RAC中的当前实例执行日志切换;
而ALTER SYSTEM ARCHIVE LOG CURRENT会对数据库中的所有实例执行日志切换。

为什么执行热备后要执行alter system archive log current 这个语句,看到很多脚本都是这样写的。是不是必须的?

一般的RMAN脚本都是这样写的,因为RMAN是可以备份归档日志的。

alter system archive log current 这样后就可以将所有的归档都备份出来了。这样做是为了保证数据的完整和一致。

推荐阅读