Oracle日志文件

Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。
Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文件主要记录了数据库的操作过程,可以在进行数据库恢复时,将重做日志文件在还原的数据库上进行执行,以达到数据库的最新状态。

Oracle数据库在运行时,可以选择是否开启归档日志,在非归档日志的情况下,Oracle所有的操作日志都写在重做日志当中,当所有重做日志文件写满时(Oracle重做日志是分组的,默认是分为三组),那么就把前面的日志文件覆盖继续写入。而在开启归档日志模式情况下,当重做日志都写满时,继续要写入日志时,会把要覆盖的日志文件写入归档日志当中,然后再对重做日志进行覆盖,因此使用归档日志利于后期进行数据恢复。

  • 查看是否开启归档日志
    1. select t.name,t.log_mode from v$database t;
  • 查看重做日志目录
    1. select * from v$logfile;

日志管理

Oracle数据库利用日志文件组对日志文件进行分组管理,Oracle数据库默认安装的是三个重做日志,三个日志文件组,每组一个日志文件。

  1. select t.group#,t.status,t.archived,b.member from v$log t,v$logfile b where t.group#=b.group#;

其中status中current表示的是当前日志文件是正在使用(写入)的。在实际使用当中,随着业务量的增大,操作数据库会变得频繁,日志文件读写切换太快,导致出现检查点等待问题,所以一般要增加或增大重做日志文件,或者直接一起增加日志文件组来解决性能问题。

因此,Oracle经常用到添加日志文件组、添加日志文件进文件组、删除日志文件、删除日志文件组四种方式对日志文件进行管理。具体命令步骤参考如下:

  • Oracle添加日志文件组

    1. alter database
    2. add logfile group n
    3. filename size m
    • group n:表示创建日志文件组的组号,在Oracle当中日志文件组的组号是唯一的。
    • filename:表示日志文件组存储的位置。
    • size m:表示日志文件组的大小,默认是50M大小。

    例,下面我们增加一个新的日志文件组4,大小100M:

  1. alter database add logfile group 4 'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO04.LOG' size 100M;

  • Oracle添加日志文件进文件组
    1. alter database
    2. add logfile member
    3. filename to group n;
    • filename:表示日志文件存储的位置。
    • group n:表示添加到那个日志文件组。
      例:
      1. alter database add logfile member 'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO05.LOG' to group 4;

  • Oracle删除日志文件

    1. alter database
    2. drop logfile member
    3. filename
    • filename:日志文件存储的位置。
    • 当日志文件组只有一个日志文件时,是不能进行删除日志文件的,必须把整个日志文件组进行删除。
      例,利用删除日志文件的命令,把刚刚添加的日志文件NEWREDO05进行删除:
      1. alter database drop logfile member 'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO05.LOG'
      执行完代码,在查下日志文件,发现日志文件NEWREDO05已经删除了
  • Oracle删除日志文件组

    1. alter database drop logfile group n

    例:

    1. alter database drop logfile group 4;

删除日志文件须要注意例如以下几点:

  • 该日志文件所在的的日志文件组不能处于current状态,须要运行一次手动日志切换,将该日志文件组的状态改动为inactive
  • 该日志文件所在的日志文件组中必须包括有其它的日志成员。
  • 假设数据库执行在归档模式下,则应该在删除日志文件之前,确定它所在的日志文件组已经被归档,否则会导致数据丢失。
文档更新时间: 2020-10-20 16:07   作者:张尚