Oracle LogMiner详细讲解

2023-12-07 05:08
文章标签 oracle 讲解 详细 logminer

本文主要是介绍Oracle LogMiner详细讲解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一:相关概念

1.Logminer是什么?

   LogMiner是Oracle数据库提供的一个工具,它用于分析重做日志和归档日志所记载的事务操作。

   Logminer是oracle从8i开始提供的用于分析重做日志信息的工具,它包括DBMS_LOGMNR和DBMS_LOGMNR_D两个package,后边的D是字典的意思。它既能分析redo log file,也能分析归档后的archive log file。在分析日志的过程中需要使用数据字典,一般先生成数据字典文件后使用,10g版本还可以使用在线数据字典

   Logminer也可以分析其它数据库的重做日志文件,但是必须使用重做日志所在数据库的数据字典,否则会出现无法识别的乱码。另外被分析数据库的操作系统平台最好和当前Logminer所在数据库的运行平台一样,且block size相同

2.LogMiner的功能:

  1)确定数据库的逻辑损坏时间

   通过LogMiner可以准确定位该误操作的执行时间和SCN值,然后通过基于时间恢复或者基于SCN恢复可以完全恢复该表数据。

   SQL>selectscn_to_timestamp(10135546249879) from dual;
   SQL>SELECTtimestamp_to_scn(to_timestamp('2013-3-27 6:06:06','yyyy-mm-ddhh24:mi:ss')) FROM dual;

  2)确定事务级要执行的精细逻辑恢复操作

   通过LogMiner可以取得任何用户的DML操作及相应的UNDO操作,通过执行UNDO操作可以取消用户的错误操作。

  3)执行后续审计

   通过LogMiner可以跟踪Oracle数据库的所有DML、DDL和DCL操作,从而取得执行这些操作的时间顺序、执行这些操作的用户等信息。

3.LogMiner的安装方法:

 

 (1)创建DBMS_LOGMNR:@D:\app\wangxianwei\product\11.2.0\dbhome_1\RDBMS\ADMIN\dbmslm.sql

       Oracle <wbr>LogMiner用法详解

 (2)创建DBMS_LOGMNR_D:@D:\app\wangxianwei\product\11.2.0\dbhome_1\RDBMS\ADMIN\dbmslmd.sql

      Oracle <wbr>LogMiner用法详解
4.LogMiner不支持的数据类型和表存储属性

   bfile;
   抽象数据类型;
   集合类型(嵌套表和varray);
   参照对象;
   xmltype;
   具有LOB列的索引组织表;
   使用compress特征的表。
   除以上类型外,基本上都是支持的,不再列举

5.LogMiner的配置要求

   (1)源数据库和分析数据库必须运行在相同硬件平台上;

   (2)分析数据库可以是独立数据库或源数据库;

   (3)分析数据库的版本不能低于源数据库的版本;

   (4)分析数据库与源数据库必须具有相同的字符集;

6.注意事项

   (1)LogMiner字典必须在源数据库中生成

  (2)当分析多个重做日志和归档日志时,它们必须是同一个源数据库的重做日志和归档日志

   (3)当分析多个重做日志和归档日志时,它们必须具有相同的resetlogsscn

  (4)当分析的重做日志和归档日志必须在Oracle8.0版本以上

7.什么是补充日志,补充日志的作用是什么?

  重做日志用于实现例程恢复和介质恢复,这些操作所需要的数据被自动记录在重做日志中。但是,重做应用可能还需要记载其他列信息到重做日志中,记录其他列的日志过程被称为补充日志

  默认情况下,Oracle数据库没有提供任何补充日志,从而导致默认情况下LogMiner无法支持以下特征:

  (1)索引簇、链行和迁移行;

  (2)直接路径插入;

  (3)摘取LogMiner字典到重做日志;

  (4)跟踪DDL;

  (5)生成键列的SQL_REDO和SQL_UNDO信息;

  (6)LONG和LOB数据类型。

因此,为了充分利用LogMiner提供的特征,必须激活补充日志。在数据库级激活补充日志的示例如下:

   SQL>alter database add supplemental log data;

       数据库已更改。

注意:激活不用重启数据库,数据库联机即可。

二、LogMiner两种使用类型,一种是使用源数据库的数据字典分析DML操作,别一种是摘取LogMiner数据字典到字典文件分析DDL操作。

1.1使用源数据库的数据字典(Onlinecatalog)来分析DML操作

    在做实验之前,检查下suppplemental logging:

    SQL> SELECT SUPPLEMENTAL_LOG_DATA_MIN FROMV$DATABASE;

         SUPPLEME

          --------

           YES

    如果是YES 或者IMPLICIT则表明已经生效了,否则需要启动:

    SQL> ALTER DATABASE ADD SUPPLEMENTAL LOGDATA;

         Database altered.

1.2、建立日志分析列表:

添加要分析的日志文件 

SQL> execute

    dbms_logmnr.add_logfile(logfilename=>'日志文件',options=>dbms_logmnr.new);

继续添加

SQL>execute

    dbms_logmnr.add_logfile(logfilename=>'日志文件',options=>dbms_logmnr.addfile);   

   需要特别注意的是,继续添加OPTIONS选项是ADDFILE

移除分析日志文件

SQL> execute

    dbms_logmnr.remove_logfile(logfilename=>'日志文件');   

1.3、启动LogMiner

SQL> execute

    dbms_logmnr.start_logmnr(Options =>DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG)

1.4、查看日志分析结果

SQL> selectusername,scn,timestamp,sql_redo from v$logmnr_contents

1.5、结束LogMiner

SQL>dbms_logminer.end_logmnr;

2.摘取LogMiner字典到字典文件分析DDL操作

2.1、使用字典文件,请查看数据库是否配置utl_file_dir这个参数为字典文件的目录。配置该参数后,需要重启数据库

SQL> show parameter utl;

    NAME                                TYPE       VALUE                         

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

    create_stored_outlines              string                                    

    utl_file_dir                        string                          

SQL> alter system setutl_file_dir='D:/oracle/logminer' scope=spfile;

    System altered.

    需要特别注意的是:修改此参数后需要重启数据库,切记!!!!

2.2、建立字典文件:

SQL> execute

    dbms_logmnr_d.build('文件名.ora','文件位置',dbms_logmnr_d.store_in_flat_file);

2.3、建立日志分析列表:

添加要分析的日志文件 

SQL> execute

    dbms_logmnr.add_logfile(logfilename=>'日志文件',options=>dbms_logmnr.new);

继续添加

SQL> execute

    dbms_logmnr.add_logfile(logfilename=>'日志文件',options=>dbms_logmnr.addfile);   

   需要特别注意的是,继续添加OPTIONS选项是ADDFILE

移除分析日志文件

SQL> execute

    dbms_logmnr.remove_logfile(logfilename=>'日志文件');   

2.4、启动LogMiner

SQL> execute

    dbms_logmnr.start_logmnr(

                              dictfilename=>'D:文件',

                              options=>dbms_logmnr.ddl_dict_tracking

                             );

2.5、查询分析日志结果:

SQL> selectusername,scn,timestamp,sql_redo from v$logmnr_contents;

    需要特别注意的是v$logmnr_contents内容保存了日志的内容,只在当前会话有效,

2.6、结束LogMiner

SQL> execute dbms_logmnr.end_logmnr;

   友情提示:DBMS_LOGMINER包中的方法及参数详见两个创建SQL

这篇关于Oracle LogMiner详细讲解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/464581

相关文章

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

arduino ide安装详细步骤

​ 大家好,我是程序员小羊! 前言: Arduino IDE 是一个专为编程 Arduino 微控制器设计的集成开发环境,使用起来非常方便。下面将介绍如何在不同平台上安装 Arduino IDE 的详细步骤,包括 Windows、Mac 和 Linux 系统。 一、在 Windows 上安装 Arduino IDE 1. 下载 Arduino IDE 打开 Arduino 官网

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla

GPT系列之:GPT-1,GPT-2,GPT-3详细解读

一、GPT1 论文:Improving Language Understanding by Generative Pre-Training 链接:https://cdn.openai.com/research-covers/languageunsupervised/language_understanding_paper.pdf 启发点:生成loss和微调loss同时作用,让下游任务来适应预训

ORACLE 11g 创建数据库时 Enterprise Manager配置失败的解决办法 无法打开OEM的解决办法

在win7 64位系统下安装oracle11g,在使用Database configuration Assistant创建数据库时,在创建到85%的时候报错,错误如下: 解决办法: 在listener.ora中增加对BlueAeri-PC或ip地址的侦听,具体步骤如下: 1.启动Net Manager,在“监听程序”--Listener下添加一个地址,主机名写计

Oracle Start With关键字

Oracle Start With关键字 前言 旨在记录一些Oracle使用中遇到的各种各样的问题. 同时希望能帮到和我遇到同样问题的人. Start With (树查询) 问题描述: 在数据库中, 有一种比较常见得 设计模式, 层级结构 设计模式, 具体到 Oracle table中, 字段特点如下: ID, DSC, PID; 三个字段, 分别表示 当前标识的 ID(主键), DSC 当

oracle分页和mysql分页

mysql 分页 --查前5 数据select * from table_name limit 0,5 select * from table_name limit 5 --limit关键字的用法:LIMIT [offset,] rows--offset指定要返回的第一行的偏移量,rows第二个指定返回行的最大数目。初始行的偏移量是0(不是1)。   oracle 分页 --查前1-9

多路转接之select(fd_set介绍,参数详细介绍),实现非阻塞式网络通信

目录 多路转接之select 引入 介绍 fd_set 函数原型 nfds readfds / writefds / exceptfds readfds  总结  fd_set操作接口  timeout timevalue 结构体 传入值 返回值 代码 注意点 -- 调用函数 select的参数填充  获取新连接 注意点 -- 通信时的调用函数 添加新fd到

【详细介绍一下GEE】

GEE(Google Earth Engine)是一个强大的云计算平台,它允许用户处理和分析大规模的地球科学数据集,如卫星图像、气候模型输出等。以下是对GEE用法的详细介绍: 一、平台访问与账户设置 访问GEE平台: 用户可以通过访问Google Earth Engine的官方网站来开始使用GEE。 创建账户: 用户需要注册并登录Google账户,然后申请访问GEE平台。申请过程可能需要提