`
yangzb
  • 浏览: 3507100 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Oracle中用LogMiner分析重做及归档日志

阅读更多

LogMiner是集成在Oracle8i/Oracle9i数据库 产品中的日志分析工具,通过该工具可以分析重做日志和归档日志中的所有事务变化,并能准确地确定各种DML和DDL操作的具体时间和SCN值。对重做日志和归档日志进行分析的目的是为了恢复由于执行了误操作而丢失的数据。

使用LogMiner可实现:①确定数据逻辑损坏的时间。例如,用户执行了DROP TABLE和TRUNCATE TABLE命令等误操作后,使用LogMiner可以准确定位执行这些误操作的具体时间。注意:Oracle8i只能还原DML操作,不能还原DDL操 作;Oracle9i可以还原DDL以及DML操作。②跟踪用户执行的事务变化操作。使用LogMiner不仅可以跟踪用户所执行的各种DML操作和 DDL操作,而且还可以取得数据变化。③跟踪表的DML操作,使用LogMiner可以跟踪在表上所发生的所有事务变化。

下面以Oracle8i(8.1.5)for Windows 2000/NT为例说明如何使用LogMiner对重做日志和归档日志进行分析。本文进行的所有操作均在该环境下验证通过,文中使用的数据库 名为phj,Oracle_sid为phj。

一、日志操作模式

Oracle数据库 对日志的管理模式有两种,即:非归档模式和归档模式。在建立或安装Oracle数据库 时,如果没有指定日志操作模式,则默认为非归档模式(NOARCHIVELOG)。数据库 建立之后,用户可以根据需要修改数据库 日志的操作模式。

1.非归档模式(NOARCHIVELOG)

非归档模式是指不保存重做日志的日志操作模式,这种日志操作模式只能用于保护实例失败(如系统断电),而不能用于保护介质失败(数据库 物理文件损坏)。

非归档模式的工作过程如下:假设数据库 只 有两个日志组,且当前日志组为日志组一,日志序列号为1。当事务变化填满日志组一时,系统会切换到日志组二,并且LGWR进程将事务变化写入该日志组,日 志序列号变为2;而当事务变化填满日志组二时,系统又自动切换回日志组一,此时日志序列号变为3,并且日志序列号3所对应的事务变化会覆盖日志序列号1所 对应的事务变化,依此类推。

2.归档模式(ARCHIVELOG)

归档模式是指将重做日志内容保存到归档日志中的日志操作模式。在这种日志操作模式下,当进行日志切换时ARCH进程会将重做日志的内容复制到归档日志中。例如,假设数据库 只 包含两个日志组,LGWR进程首先将事务变化写入日志组一,此时日志序列号为1;当事务变化填满日志组一时,系统将自动切换到日志组二,并将事务变化写入 日志组二,此时日志序列号变为2,同时后台进程ARCn会将日志组一的内容保存到归档日志文件1中;而当事务变化填满日志组二时,系统自动切换回日志组 一,并将事务变化写入日志组一,此时日志序列号变为3,同时后台进程ARCn会将日志组二的内容保存到归档日志文件2中,依此类推。

3.改变日志的操作模式为自动归档模式

①修改数据库 的参数文件,在参数文件后添加如下参数:

 

  
  log_archive_start = true
  
  log_archive_dest_1 = "location=C:\Oracle\phj\archive"
  
  log_archive_format = "T%TS%S.ARC"

说明:第一个参数在重启数据库 时将自动启动ARCH进程;第二个参数指出归档日志存放的位置;第三个参数说明归档日志的文件名格式,%T取重做线程号,%S取日志序列号;

②重启并装载数据库

 

  
  sqlplus internal/oracle@phj
  
  shutdown immediate
  
  startup mount pfile=%Oracle_Home%\database\initphj.ora
  
  alter database archivelog
  
  alter database open

4.生成归档日志

下面以分析TMP表的DDL和DML操作为例,介绍使用LogMiner分析重做日志和归档日志的全过程。我们首先执行以下语句在表TMP上执行DDL以及DML操作,并生成归档日志:

 

  
  sqlplus internal/oracle@phj
  
  create table tmp(name varchar2(10),no number(3));
  
  alter system switch logfile;
  
  insert into tmp values(‘liming’,112);
  
  update tmp set no=200;
  
  commit;
  
  alter system switch logfile;
  
  delete from tmp;
  
  alter system switch logfile;
 

通过上面的操作会产生三个连续的归档日志文件。

二、建立字典文件

字典文件用于存放表及对象ID号之间的对应关系。当使用字典文件时,它会在表名和对象ID号之间建立一一对应的关系。因此需要注意,如果用户建立了新表之后,并且将来可能会对该表进行日志分析,那么就需要重新建立字典文件,以将其对象名及对象ID号存放到字典文件中。

1.修改参数文件,添加参数:UTL_FILE_DIR=C:\Oracle\phj\logmnr

目录logmnr必须事先手工建立,该目录用于存放产生的字典文件,目录名称可以自定。

2.重新启动数据库

 

  
  sqlplus internal/oracle@phj
  
  shutdown immediate
  
  startup pfile=%Oracle_Home%\database\initphj.ora

3.建立字典文件

 

  
  BEGIN
  
   dbms_logmnr_d.build(
  
   dictionary_filename=>’dict.ora’,
  
   dictionary_location=>’c:\oracle\phj\logmnr’);
  
  END;
  
  /

注意:参数dictionary_filename用以指定字典文件的文件名;参数 dictionary_location用于指定存放字典文件所在的目录,该目录必须与初始化参数UTL_FILE_DIR的值一致。如果指定的字典文件 名dict.ora已经存在,则应在执行此操作前将其彻底删除(从垃圾箱中删除),否则执行该过程将失败。

三、建立日志分析列表

建立日志分析列表必须在MOUNT或NOMOUNT状态下完成。

1.停止并装载数据库

 

  
  sqlplus internal/oracle@phj
  
  shutdown immediate
  
  startup mount pfile=%Oracle_Home%\database\initphj.ora

2.建立日志分析列表

在“生成归档日志”的操作中已经生成了三个连续的归档日志文件,为便于分析我们重新复制这三个归档日志文件并分别命名为:test1.arc、test2.arc、test3.arc。通过以下操作建立日志分析列表:

 

  
   BEGIN
  
  dbms_logmnr.add_logfile(
  
  options=>dbms_logmnr.new,
  
   logfilename=>’c:\oracle\phj\archive\test1.arc’);
  
   END;
  
  /

3.增加其它欲进行分析的日志文件

 

  
   BEGIN
  
  dbms_logmnr.add_logfile(
  
  options=>dbms_logmnr.addfile,
  
   logfilename=>’c:\oracle\phj\ archive \test2.arc’);
  
   END;
  
  /

用同样的方法将归档日志文件test3.arc增加到日志分析列表中。可以通过动态性能视图v$logmnr_logs查看日志分析列表中有哪些待分析的日志文件。

 

  
  SQL> select filename from v$logmnr_logs;
  
  FILENAME
  
  ----------------------------------------
  
  c:\oracle\phj\archive\test1.arc
  
  c:\oracle\phj\archive\test2.arc
  
  c:\oracle\phj\archive\test3.arc

四、启动LogMiner执行分析

1.分析重做日志和归档日志

 

  
   BEGIN
  
  dbms_logmnr.start_logmnr(
  
  dictfilename=>’c:\oracle\phj\logmnr\dict.ora’,
  
   starttime=>to_date(’2003-02-10:10:05:00’,’YYYY-MM-DD:HH24:MI:SS’),
  
   endtime=>to_date(’2003-02-10:10:17:00’,’YYYY-MM-DD:HH24:MI:SS’)
  
  );
  
   END;
  
  /

注意:此过程能否执行成功的关键是给出的starttime(起始时间)和 endtime(终止时间)应在一个有效的范围内。特别是终止时间,应小于或等于归档日志的建立时间;如果大于归档日志的建立时间,则不能执行分析过程。 分析多个归档日志时,这些归档日志最好是连续的。

2.查看日志分析结果

上面对日志进行分析的结果存放在动态性能视图v$logmnr_contents中,通过查询该动态性能视图可以取得所有DML以及其反操作。

 

  
  SQL> select operation,sql_redo,sql_undo
  
  2 from v$logmnr_contents
  
  3 where seg_name='TMP';
  
  OPERATION SQL_REDO SQL_UNDO
  
  ----------- --------------------- --------------------------
  
  INSERT insert into SYS.TMP…… delete from SYS.TMP ……
  
  UPDATE update SYS.TMP set NO …… update SYS.TMP set ……
  
  DELETE delete from SYS.TMP …… insert into SYS.TMP ……

根据需要可以从动态性能视图v$logmnr_contents中获取更多的有用信息,限于篇幅此不赘述。对重做日志进行分析的方法与对归档日志分析的方法一样,只是在建立日志分析列表时,需将重做日志文件添加到日志分析列表中。

分享到:
评论

相关推荐

    【数据库】Oracle异机logminer日志分析-.docx

    Oracle LogMiner 是一个功能强大且常用的日志分析工具,能够便捷地从在线或归档日志中获取内容。通常情况下,在数据库本机上进行日志分析,通过数据字典文件来解析,配置过程需要重启数据库服务器。然而,在实际生产...

    分析Oracle8i/9i的重做日志和归档日志

    LogMiner是Oracle8i和Oracle9i提供的一个内置日志分析工具,它能够帮助管理员分析重做日志和归档日志,从而追踪数据库中的事务变化,包括DML(数据操纵语言)和DDL(数据定义语言)操作。LogMiner不仅能够确定这些...

    oracle日志分析工具LogMiner使用.

    Oracle 日志分析工具 LogMiner 使用 Oracle 日志分析工具 LogMiner 是 Oracle 数据库中的一种功能强大且灵活的日志分析工具,它可以帮助数据库管理员、开发人员和用户快速地对数据库进行日志分析和问题诊断。下面是...

    oracle归档日志挖掘详细步骤.docx

    总的来说,Oracle数据库归档日志挖掘涉及多个步骤,包括切换日志、选择分析时间范围、添加日志文件、启动和查询分析,以及关闭LogMiner。通过理解并遵循这些步骤,用户可以有效地挖掘和分析归档日志,从而更好地管理...

    基于LogMiner的Oracle数据库日志分析.pdf

    LogMiner 及 LogViewer 是 Oracle 数据库日志分析的重要工具,对 Oracle 数据库的维护和管理具有重要意义。 六、相关知识点 * Oracle 数据库日志文件 * LogMiner 工具 * LogViewer 工具 * Oracle 数据库日志分析 *...

    Oracle日志管理logminer使用

    Oracle中的日志主要包括重做日志(Redo Logs)和归档日志(Archived Logs)。其中,重做日志用于记录对数据库的所有更改;而归档日志则是在数据库运行在归档模式下时,将已经写入重做日志但尚未被覆盖的数据进行备份...

    Oracle_10g_Logminer_研究及测试

    3. 配置要分析的日志文件:LogMiner可以分析在线重做日志或归档日志。使用`DBMS_LOGMNR.ADD_LOGFILE`过程来添加要分析的日志文件。 4. 启动LogMiner分析:通过调用`DBMS_LOGMNR.START_LOGMNR`并提供相应的选项...

    Oracle logMiner

    Oracle LogMiner是Oracle数据库内置的一个实用工具,用于分析重做日志文件(redo logs),帮助DBA(数据库管理员)和开发人员理解数据库中的事务历史、数据更改以及系统活动。这个工具无需创建归档模式,就能对在线...

    Oracle LogMiner

    在IT领域,尤其是在数据库管理与监控技术中,Oracle LogMiner是一个极其重要的工具,它为DBA(数据库管理员)和开发人员提供了强大的日志分析能力。以下是对Oracle LogMiner及其相关概念的深入解析。 ### Oracle ...

    oracle日志分析工具LogMiner使用

    Oracle LogMiner是Oracle数据库提供的一个强大工具,用于分析重做日志文件,提取数据库中的更改记录(即SCN序列)。通过LogMiner,我们可以追踪并监控数据库表上的变更情况,这对于故障诊断、审计、数据恢复等方面...

    oracle日志分析工具LogMiner的使用

    Oracle的日志分析工具LogMiner是Oracle数据库内置的一个强大功能,用于分析数据库的redo logs,以获取关于数据库操作的历史信息。LogMiner可以帮助DBA进行性能优化、故障排查和审计等任务。以下将详细介绍LogMiner的...

    浅谈Oracle日志分析工具LogMiner.pdf

    日志分析列表指定了要分析的重做日志文件或归档日志文件。需要注意的是,首次添加日志文件时必须使用特定选项,之后添加其他日志文件则使用其他选项。 最后,启动LogMiner是整个操作流程的第三步。在将日志文件添加...

    Oracle 9i LogMiner工具使用说明

    - **分析多个数据库的重做日志文件**:LogMiner不仅可以分析本数据库的重做日志文件,还可以分析其他数据库的重做日志文件。这对于跨数据库的审计和数据分析非常有用。 - **定制化的数据过滤**:通过设定过滤条件,...

    Oracle Logminer

    - **重做日志文件**:分析的重做日志和归档日志应属于同一源数据库,具有相同的resetlogs SCN,并且是Oracle 8.0及以上版本。 **补充日志(Supplemental Logging)**是确保Logminer有效工作的一个关键设置。默认...

    Oracle中使用LogMiner进行日志分析.pdf

    Oracle中的LogMiner是一个强大的日志分析工具,自Oracle 8i版本开始提供,用于解析重做日志文件(归档日志文件),提取其中的DML操作(INSERT、UPDATE、DELETE等)以及相关的回滚SQL语句。LogMiner没有图形用户界面...

    Oracle 日志挖掘(LogMiner)使用详解

    Logminer依赖于2个包:DBMS_LOGMNR和DBMS_LOGMNR_D,Oracle 11g默认已安装 Logminer 基本使用步骤 <1>. Specify a LogMiner dictionary. 指定Logminer字典 <2>. Specify a list of redo log files for analysis. ...

    Oracle_10g_LogMiner

    Oracle 10g LogMiner 是Oracle数据库的一个内置工具,用于分析数据库的重做日志文件,从而获取关于事务的历史信息、SQL语句及其影响的数据变化。LogMiner 提供了一个方便的方式来审计和理解数据库中发生的变化,而...

Global site tag (gtag.js) - Google Analytics