Oracle 10g Logminer 研究及测试

上传人:飞****9 文档编号:130668551 上传时间:2020-04-30 格式:DOC 页数:26 大小:36.88KB
返回 下载 相关 举报
Oracle 10g Logminer 研究及测试_第1页
第1页 / 共26页
Oracle 10g Logminer 研究及测试_第2页
第2页 / 共26页
Oracle 10g Logminer 研究及测试_第3页
第3页 / 共26页
Oracle 10g Logminer 研究及测试_第4页
第4页 / 共26页
Oracle 10g Logminer 研究及测试_第5页
第5页 / 共26页
点击查看更多>>
资源描述

《Oracle 10g Logminer 研究及测试》由会员分享,可在线阅读,更多相关《Oracle 10g Logminer 研究及测试(26页珍藏版)》请在金锄头文库上搜索。

1、 Oracle 10g Logminer 研究及测试 收藏 LogMiner提供了一个处理重做日志文件并将其内容翻译成代表对数据库的逻辑操作的SQL语句的过程。LogMiner运行在Oracle版本8.1或者更高版本中。一,如何使用Logminer: 先要安装logminer的两个包;以SYS用户运行下面两个脚本,其中第一个脚本dbmslm.sql用来创建DBMS_LOGMNR包,该包用来分析日志文件。第二个脚本dbmslmd.sql用来创建DBMS_LOGMNR_D包,该包用来创建数据字典文件。 D:oracleproduct10.2.0db_1RDBMSADMINsqlplus /nolo

2、gSQL*Plus: Release 10.2.0.4.0 - Production on星期五4月10 17:49:02 2009Copyright (c) 1982, 2007, Oracle. All Rights Reserved.SQL conn sys/oracle as sysdba已连接。SQLSQL dbmslm.sql程序包已创建。授权成功。SQLSQL dbmslmd.sql程序包已创建。二,创建数据字典文件 数据字典文件是一个文本文件,使用包DBMS_LOGMNR_D来创建,如果我们要分析的数据库中的表有变化(比如表结构有变化等),影响到库的数据字典也发生变化。另外一种

3、情况是在分析另外一个数据库文件的重做日志时,也必须要重新生成一遍被分析数据库的数据字典文件。 首先需要修改参数UTL_FILE_DIR ,该参数值为服务器中放置数据字典文件的目录,10g中我们通过动态修改参数的方式来修改,然后重新启动数据库生效。其中logs_utl_file目录先期建立好。SQL alter system set UTL_FILE_DIR=d:oracleproduct10.2.0oradatatestlogs_utl_file scope=spfile; 系统已更改。 SQL shutdown immediate数据库已经关闭。已经卸载数据库。ORACLE例程已经关闭。SQ

4、LSQL startupORACLE例程已经启动。Total System Global Area 167772160 bytesFixed Size 1295608 bytesVariable Size 125831944 bytesDatabase Buffers 33554432 bytesRedo Buffers 7090176 bytes数据库装载完毕。数据库已经打开。SQLSQL show parameter UTL_FILENAME TYPE- -VALUE-utl_file_dir stringd:oracleproduct10.2.0oradatatestlogs_utl_f

5、ileSQL然后创建数据字典文件:BEGINdbms_logmnr_d.build(dictionary_filename = logminer_dict.ora, dictionary_location = D:oracleproduct10.2.0oradatatestlogs_utl_file);END;/OK ,可以看到在logs_ult_file中已经生成了logminer_dict.ora数据字典文件。数据字典文件是可以打开的文本文件。有兴趣可以打开看看。execute dbms_logmnr_d.build(shwdict.ora,d:lick); /本人使用的创建语句创建数据字

6、典是让logminer引用实际到内部数据字典中的部分是使用对象的名称,而不是系统内部的16进制的ID. 三,创建要分析的日志文件(在线日志或归档日志)的列表(1)分析在线的重做日志A。建立列表SQL execute dbms_logmnr.add_logfile(LogFileName=d:oracleproduct10.2.0oradatatestredo01.log, ptions=dbms_logmnr.new);PL/SQL过程已成功完成。B。添加其他日至文件到列表 SQL execute dbms_logmnr.add_logfile(LogFileName=d:oracleprod

7、uct10.2.0oradatatestredo02.log, ptions=dbms_logmnr.addfile);PL/SQL过程已成功完成。SQL execute dbms_logmnr.add_logfile(LogFileName=d:oracleproduct10.2.0oradatatestredo03.log, ptions=dbms_logmnr.addfile);PL/SQL过程已成功完成。(2)分析归档的重做日志 A。建立列表SQL execute dbms_logmnr.add_logfile(LogFileName=d:oracleproduct10.2.0orad

8、ataarchiveARC00052_0684166863.001, ptions=dbms_logmnr.new);PL/SQL过程已成功完成。B。添加其他日志文件到列表 SQL execute dbms_logmnr.add_logfile(LogFileName=d:oracleproduct10.2.0oradataarchiveARC00053_0684166863.001, ptions=dbms_logmnr.addfile);PL/SQL过程已成功完成。 如果你觉得不需要分析已经在列表中的在线或归档日志,可以通过removefile命令删除:SQL execute dbms_l

9、ogmnr.add_logfile(LogFileName=d:oracleproduct10.2.0oradataarchiveARC00053_0684166863.001, ptions=dbms_logmnr.removefile);PL/SQL过程已成功完成。四,使用Logminer进行日志分析无限制条件:SQL execute dbms_logmnr.start_logmnr(DictFileName= D:oracleproduct10.2.0oradatatestlogs_utl_filelogminer_dict.ora) ;PL/SQL过程已成功完成。有限制条件:通过对过程

10、DBMS_LOGMNR.START_LOGMNR中的时间或者SCN参数的设置,可以缩小分析日志文件的范围:如我们仅仅分析2009年2月23日到2005年7月26日的日志:SQL execute dbms_logmnr.start_logmnr(DictFileName = D:oracleproduct10.2.0oradatatestlogs_utl_filelogminer_dict.ora ,StartTime = to_date(2009-2-23 00:00:00,YYYY-MM-DD HH24:MI:SS)EndTime = to_date(2009-2-26 23:59:59,Y

11、YYY-MM-DD HH24:MI:SS ); 相关的参数如下:参数参数类型默认值含义StartScn数字型0分析重作日志中SCNStartScn日志文件部分EndScn数字型0分析重作日志中SCNEndScn日志文件部分StartTime日期型1998-01-01分析重作日志中时间戳StartTime的日志文件部分EndTime日期型2988-01-01分析重作日志中时间戳EndTime的日志文件部分DictFileName字符型字典文件该文件包含一个数据库目录的快照。使用该文件可以使得到的分析结果是可以理解的文本形式,而非系统内部的16进制Options BINARY_INTEGER 0系

12、统调试参数,实际很少使用五,得到分析结果: 到现在为止,我们已经分析得到了重作日志文件中的内容。动态性能视图v$logmnr_contents包含LogMiner分析得到的所有的信息。SELECT sql_redo FROM v$logmnr_contents;如果我们仅仅想知道某个用户对于某张表的操作,可以通过下面的SQL查询得到,该查询可以得到用户TONY对表R_WIP_TST所作的一切工作。SQL; SELECT sql_redo FROM v$logmnr_contents WHERE username=TONY AND tablename=R_WIP_TST; 需要强调一点的是,视图

13、v$logmnr_contents中的分析结果仅在我们运行过程dbms_logmrn.start_logmnr 这个会话的生命期中存在(如果执行了DBMS_LOGMNR.END_LOGMNR分析结果将消失)。这是因为所有的LogMiner存储都在PGA内存中,所有其他的进程是看不到它的,同时随着进程的结束,分析结果也随之消失。如果需要,可以通过removefile命令删除日志分析文件。SQL execute dbms_logmnr.add_logfile(LogFileName=d:oracleproduct10.2.0oradataarchiveARC00052_0684166863.001, ptions=dbms_logmnr.removefile);六,使用DBMS_LOGMNR.END_LOGMNR结束日志分析过程,释放内存。最后,使用过程DBMS_LOGMNR.END_LOGMNR终止日志分析事务,此时PGA内存区域被清除,分析结果也随之不再存在。SQL execute dbms_logmnr.end_logmnr; 作为Oracle DBA,我们有时候需要追踪数据误删除或用户的恶意操作情况,此时我们不仅需要查出执行这

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 学术论文 > 管理论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号