首页 > 数据库 >探索Oracle之LogMiner 最佳实践一

探索Oracle之LogMiner 最佳实践一

时间:2023-06-25 14:32:10浏览次数:58  
标签:LogMiner NAME 探索 logmnr SQL Oracle WWL TEST03


探索Oracle之LogMiner 最佳实践一

作者:吴伟龙PrudentWoo



示例:


       这是一个LogMiner示例配置。在这个图中,位于波士顿的源数据库生成重做日志文件,这些文件被归档并发送到旧金山的数据库。已将LogMiner字典提取到这些重做日志文件中。LogMiner将实际分析重做日志文件的挖掘数据库位于旧金山。两边的数据库版本不要求一样。


LogMiner数据字典选项:


       LogMiner需要一个字典来将对象id转换为对象名称,当它返回重做数据给你时。LogMiner为您提供了提供字典的三个选项:

使用Online Catalog: Oracle建议您将访问源数据库使用这个选项,同时创建重做日志文件,并在预期的表中没有对列定义进行更改。这是最高效、最容易使用的选项。

将LogMiner字典提取到重做日志文件中: Oracle建议您使用此选项时,不要期望访问重新创建日志文件的源数据库,或者您预期会对感兴趣的表中的列定义进行更改。

将LogMiner字典提取到一个平文本文件: 这个选项是为了向后兼容以前的版本而保留的。此选项并不保证事务一致性。Oracle建议您使用联机目录或从重做日志文件中提取字典。

我们既然已经了解了什么是LogMiner之后,那么我们现在来开始做实验,用实验证明我说的话是对的:

 

LogMiner组件检查:

       首先我们要确认数据库是否已经拥有必须的包,如果没有则需要运行两个包:@?/rdbms/admin/dbmslm.sql脚本用来安装DBMS_LOGMNR包,这个包用户来分析日志文件;@?/rdbms/admin/dbmslmd.sql脚本用来安装DBMS_LOGMNR_D包,这个包主要是创建LogMiner所必须的数据字典。

SQL> conn / as sysdba
Connected.
SQL> @?/rdbms/admin/dbmslm.sql

Package created.


Grant succeeded.


Synonym created.

SQL> @?/rdbms/admin/dbmslmd.sql

Package created.


Synonym created.

SQL> r
  1  SELECT DISTINCT name
  2  FROM DBA_SOURCE
  3  WHERE type = 'PACKAGE'
  4  AND upper(text) LIKE upper('%logmnr%')
  5  order by name

NAME
-------------------------
DBMS_LOGMNR
DBMS_LOGMNR_D
DBMS_LOGMNR_INTERNAL
DBMS_LOGMNR_LOGREP_DICT
DBMS_LOGMNR_SESSION
LOGMNR_DICT_CACHE
LOGMNR_EM_SUPPORT

7 rows selected.



一、同库基于Redo的LogMiner

1、创建测试表:

SQL> conn wwl/wwl
Connected.

SQL> create table test02 (id number(10),name varchar2(200));
Table created.

2、对测试表进行 增加,更新的操作并提交


SQL> insert into test02 values(1,'woo');
1 row created.

SQL> commit;
Commit complete.

SQL> update test02 set name='wwl' where name='woo';
1 row updated.

SQL> commit;
Commit complete.

3、查询当前的RedoLog File,定位刚才操作所在的RedoLog File:

SQL> select group#,archived,status from v$log;

    GROUP# ARC STATUS
---------- --- ----------------
	 1 YES INACTIVE
	 2 YES INACTIVE
	 3 NO  CURRENT

4、至此,环境已经构建完成。

5、添加状态为CURRENT的RedoLog File到LogMiner中

SQL> exec dbms_logmnr.add_logfile(logfilename=>'/DBSoft/oracle/oradata/woo/redo03.log', options=>dbms_logmnr.new);
PL/SQL procedure successfully completed.

6、启动LogMiner进行分析

SQL> execute dbms_logmnr.start_logmnr(options=>dbms_logmnr.dict_from_online_catalog);
PL/SQL procedure successfully completed.

7、查看分析后的结果

SQL> set linesize 300
SQL> set pagesize 8096
SQL> col seg_name format a6
SQL> col seg_owner format a4
SQL> col sql_redo format a70
SQL> col sql_undo format a70
SQL> SELECT SEG_OWNER, SEG_NAME, SQL_REDO, SQL_UNDO
    2 FROM v$LOGMNR_CONTENTS
    3 WHERE SEG_NAME = 'TEST02' and seg_owner='WWL';  

SEG_ SEG_NA SQL_REDO								   SQL_UNDO
---- ------ ---------------------------------------------------------------------- ----------------------------------------------------------------------
WWL  TEST02 create table test02 (id number(10),name varchar2(200));
WWL  TEST02 insert into "WWL"."TEST02"("ID","NAME") values ('1','woo'); 	   delete from "WWL"."TEST02" where "ID" = '1' and "NAME" = 'woo' and ROW
										   ID = 'AAAVXrAAEAAAACvAAA';

WWL  TEST02 update "WWL"."TEST02" set "NAME" = 'wwl' where "NAME" = 'woo' and ROWI update "WWL"."TEST02" set "NAME" = 'woo' where "NAME" = 'wwl' and ROWI
	    D = 'AAAVXrAAEAAAACvAAA';						   D = 'AAAVXrAAEAAAACvAAA';

8、我们可以看到在这里已经清晰的显示了之前所做所有操作的详细SQL语句,包括创建test02表,插入一条ID 为 1 和 将ID=1 更新为 ID=2。完成了整个操作的重演。




二、同库基于ArchiveLog File的LogMiner

1、创建测试表:

SQL> conn wwl/wwl
Connected.

SQL> create table test03(id number(10),name varchar2(200));

Table created.

SQL> insert into test03 values(1,'wwl');

1 row created.

SQL> insert into test03 values(2,'wwl');

1 row created.

SQL> insert into test03 values(3,'pru');

1 row created.

SQL> insert into test03 values(4,'pru');

1 row created.


增删改操作:
SQL> insert into test03 values(4,'pru');

1 row created.

SQL> update test03 set name='woo' where id=2;

1 row updated.

SQL> delete from test03 where id=4;

1 row deleted.

SQL> commit;



2、检查刚才数据:

SQL> col name format a4
SQL> select * from test03;

	ID NAME
---------- ----
	 1 wwl
	 2 woo
	 3 pru



3、查询当前的RedoLog File,定位刚才操作所在的RedoLog File:

SQL> select thread#,sequence#,bytes,archived,status from v$log;

   THREAD#  SEQUENCE#	   BYTES ARC STATUS
---------- ---------- ---------- --- ----------------
	 1	   46	52428800 NO  CURRENT
	 1	   44	52428800 YES INACTIVE
	 1	   45	52428800 YES ACTIVE



4、查询归档日志

SQL> select SEQUENCE#,name,status from v$archived_log where name is not null and sequence#=45;

 SEQUENCE# NAME 										 S
---------- ------------------------------------------------------------------------------------- -
	45 /DBSoft/oracle/fast_recovery_area/WOO/archivelog/2017_11_21/o1_mf_1_45_f17jvko7_.arc  A

5、添加归档日志做离线分析:

SQL> execute dbms_logmnr.add_logfile(logfilename=>'/DBSoft/oracle/fast_recovery_area/WOO/archivelog/2017_11_21/o1_mf_1_45_f17jvko7_.arc',options=>dbms_logmnr.NEW);

PL/SQL procedure successfully completed.

6、启动LogMiner分析进程

SQL> execute dbms_logmnr.start_logmnr(options=>dbms_logmnr.dict_from_online_catalog);

PL/SQL procedure successfully completed.

7、查询分析结果:

SQL> col SQL_REDO format a100
SQL> col SQL_UNDO format a100
SQL> SELECT SEG_OWNER, SEG_NAME,SQL_REDO, SQL_UNDO
2 FROM v$LOGMNR_CONTENTS
3 WHERE SEG_NAME = 'TEST03' and seg_owner='WWL';

SEG_ SEG_NA SQL_REDO
---- ------ ----------------------------------------------------------------------------------------------------
SQL_UNDO
----------------------------------------------------------------------------------------------------
WWL  TEST03 create table test03(id number(10),name varchar2(200));


WWL  TEST03 insert into "WWL"."TEST03"("ID","NAME") values ('1','wwl');
delete from "WWL"."TEST03" where "ID" = '1' and "NAME" = 'wwl' and ROWID = 'AAAVXsAAEAAAAC3AAA';

WWL  TEST03 insert into "WWL"."TEST03"("ID","NAME") values ('2','wwl');
delete from "WWL"."TEST03" where "ID" = '2' and "NAME" = 'wwl' and ROWID = 'AAAVXsAAEAAAAC3AAB';

WWL  TEST03 insert into "WWL"."TEST03"("ID","NAME") values ('3','pru');
delete from "WWL"."TEST03" where "ID" = '3' and "NAME" = 'pru' and ROWID = 'AAAVXsAAEAAAAC3AAC';

WWL  TEST03 insert into "WWL"."TEST03"("ID","NAME") values ('4','pru');
delete from "WWL"."TEST03" where "ID" = '4' and "NAME" = 'pru' and ROWID = 'AAAVXsAAEAAAAC3AAD';

WWL  TEST03 update "WWL"."TEST03" set "NAME" = 'woo' where "NAME" = 'wwl' and ROWID = 'AAAVXsAAEAAAAC3AAB';
update "WWL"."TEST03" set "NAME" = 'wwl' where "NAME" = 'woo' and ROWID = 'AAAVXsAAEAAAAC3AAB';

WWL  TEST03 delete from "WWL"."TEST03" where "ID" = '4' and "NAME" = 'pru' and ROWID = 'AAAVXsAAEAAAAC3AAD';
insert into "WWL"."TEST03"("ID","NAME") values ('4','pru');

7 rows selected.



8、完了之后记得结束LogMiner:

SQL> execute dbms_logmnr.end_logmnr;
PL/SQL procedure successfully completed.



注意:


使用logminer查询表v$logmnr_contents必须在同一个会话中进行,因为分析的那些信息存储在这个session的PGA中,在别的session里面是查不到的,如果在别的session中视图查询这个视图得到如下错误:


SQL>select * from V$LOGMNR_CONTENTS;
select* from V$LOGMNR_CONTENTS
ERRORat line 1:
ORA-01306: dbms_logmnr.start_logmnr() must be invoked before selectingfrom
v$logmnr_contents

视图v$logmnr_contents中的分析结果仅在我们运行过程'dbms_logmrn.start_logmnr'这个会话的生命期中存在。这是因为所有的LogMiner存储都在PGA内存中,所有其他的进程是看不到它的,同时随着进程的结束,分析结果也随之消失。最后,使用过程DBMS_LOGMNR.END_LOGMNR终止日志分析事务,此时PGA内存区域被清除,分析结果也随之不再存在。

可以创建临时表解决这个问题

SQL>create table logmnr_tb1 as select  *from V$LOGMNR_CONTENTS;
Table created.



标签:LogMiner,NAME,探索,logmnr,SQL,Oracle,WWL,TEST03
From: https://blog.51cto.com/prudentwoo/6545744

相关文章

  • 探索Oracle之数据库升级四 11.2.0.4.0 PSU 11.2.0.4.3
    探索Oracle之数据库升级四11.2.0.4.0PSU11.2.0.4.3一、 检查当前数据库PSU号:[oracle@db01~]$cd/DBSoft/Product/11.2.4/db_1/OPatch/[oracle@db01OPatch]$lscrsdocsemdpatch.pljlibocmopatchopatch.batopatchdiagopatchdiag.batopatch.iniopatch.p......
  • 探索Oracle之数据库升级八 12c Downgrade 11gR2
    探索Oracle之数据库升级八12cDowngrade11gR2前言:      我们前面已经完成了11gR2upgradeto12c 的升级,整个过程还是比较顺利的,虽然和以前版本升级有些不太一样,但是整个难度不是太大,但是由于太多的特性不同,大大的加长了升级的时间。       但是对于Oracle12c降回......
  • C#-SQLHelper(三)_Oracle
    SqlHelper工具类/***┌──────────────────────────────────────────────────────────────┐*│描述:Oracle数据库的操作工具类*│作者:执笔小......
  • oracle 19c rpm 个性化配置安装
    简单来说就是:1.安装preinstall  :   oracle-database-preinstall-19c-1.0-1.el7.x86_64.rpm2.安装ee  : oracle-database-ee-19c-1.0-1.x86_64.rpm3.配置数据库(这个耗时最久,也是实际安装实例):  19c的RPM包下载链接,https://www.oracle.com/database/technolo......
  • 利用PadBuster自动填充Oracle的攻击
     首页→怡安的网络实验室→利用PadBuster自动填充Oracle的攻击2010年9月14日,星期二,上午10:20最近有很多关于填充甲骨文攻击的讨论,这是JulianoRizzo和ThaiDuong在今年夏天早些时候在BlackHatEurope的演讲中展示的一种攻击载体。虽然填充神谕是比较容易利用的,但如果......
  • mysql与oracle的日期时间函数小结
    本文的日期/时间全部格式化为”2016-01-0101:01:01“形式;MONITOR_TIME为数据库表字段;字符串与日期/时间相互转换函数Oracle日期/时间转字符串函数:to_char(t.MONITOR_TIME,‘yyyy-mm-ddhh24:mi:ss‘)asmonitorTime字符串转日期/时间函数:TO_Date(”2016-01-0101:01:01“,......
  • 探索WordPress:开源内容管理系统的强大功能和灵活性
    WordPress是一款广泛使用的开源内容管理系统(CMS),它提供了许多强大的功能和灵活性,使其成为建立和管理网站的首选工具。在本篇博客中,我们将深入探讨WordPress的一些关键功能和技术,以及如何最大限度地发挥其潜力。1.简单易用的界面和内容管理WordPress提供了一个直观且用户友好的管......
  • ORACLE 新闻速递 ORACLE 23C 免费提供给开发者 为什么???
    开头还是介绍一下群,如果感兴趣polardb,mongodb,mysql,postgresql,redis等有问题,有需求都可以加群群内有各大数据库行业大咖,CTO,可以解决你的问题。以下是新闻速递分析师们表示,Oracle推出新的面向开发人员版本数据库的策略变化,与该公司计划捍卫其市场主导地位和寻求采用创新方式......
  • oracle 10053事件—执行计划的解析
    文档课题:oracle10053事件—执行计划的解析.数据库:oracle11.2.0.41、理论知识在查看SQL语句的执行计划时,CBO仅显示最终结果。当执行计划明显失真时,就急需知道CBO详细的选择过程。此时10053事件便闪亮登场,通过分析生成的trace文件揭开CBO的神秘外纱。2、数据准备2.1、建测试数......
  • 探索Python的反射与内省:代码的自我察觉
    Python中的反射与内省允许代码察觉和修改它自己。反射指的是程序在运行时可以访问、检测和修改它自己的结构或行为的一种能力。而内省则更侧重于查看对象的类型和属性,比如查看一个对象是否有某个属性或方法,以及查看对象的文档字符串等。本文将深入探讨Python的反射与内省能力。一......