ITPUX技术网

交流 . 资讯 . 分享
Make progress together!
Linux操作系统下Oracle11g R2 RAC 安装配置教程
Oracle数据库培训-备份恢复-性能优化-集群容灾
Oracle数据库DBA高级工程师培训视频

Oracle LogMiner安装和使用

内容发布:707174135| 发布时间:2017-3-5 19:12:44
Oracle LogMiner安装和使用
Oracle LogMiner 是Oracle公司从产品8i以后提供的一个实际非常有用的分析工具,使用该工具可以轻松获得Oracle 重作日志文件(归档日志文件)中的具体内容,特别是,该工具可以分析出所有对于数据库操作的DML(insert、update、delete等)语句,另外还可分析得到一些必要的回滚SQL语句。该工具特别适用于调试、审计或者回退某个特定的事务。
总的说来,LogMiner工具的主要用途有:
1. 跟踪数据库的变化:可以离线的跟踪数据库的变化,而不会影响在线系统的性能。2. 回退数据库的变化:回退特定的变化数据,减少point-in-time recovery的执行。优化和扩容计划:可通过分析日志文件中的数据以分析数据增长模式。下面简单介绍LogMiner的安装及使用,我的环境是WINXP+ORACLE10R2。LogMiner安装:
要安装LogMiner工具,必须首先要运行下面这样两个脚本,这两个脚本必须均以SYS用户身份运行。其中第一个脚本用来创建DBMS_LOGMNR包,该包用来分析日志文件。第二个脚本用来创建DBMS_LOGMNR_D包,该包用来创建数据字典文件。
1.$ORACLE_HOME/rdbms/admin/dbmslm.sql
2.$ORACLE_HOME/rdbms/admin/dbmslmd.sql.
使用LogMiner工具
1.创建数据字典文件(data-dictionary)
数据字典文件是一个文本文件,使用包DBMS_LOGMNR_D来创建。如果我们要分析的数据库中的表有变化,影响到库的数据字典也发生变化,这时就需要重新创建该字典文件。另外一种情况是在分析另外一个数据库文件的重作日志时,也必须要重新生成一遍被分析数据库的数据字典文件。
在ORACLE8I的时候,首先在init.ora初始化参数文件中,指定数据字典文件的位置,也就是添加一个参数UTL_FILE_DIR,该参数值为服务器中放置数据字典文件的目录。如:
UTL_FILE_DIR=(e:\Oracle\logs)
ORACLE9I后,推荐使用SPFILE启动,可以动态调整参数;

然后创建数据字典文件

2.创建要分析的日志文件列表
Oracle的重作日志分为两种,在线(online)和离线(offline)归档日志文件,我这里主要分析归档日志,在线日志原理一样。
A.创建列表
B.添加另外的日志文件到列表

注意:






3.使用LogMiner进行日志分析
(1)        无限制条件

(2)有限制条件



参数        参数类型
默认值        含义
StartScn         数字型(Number)         0        分析重作日志中SCN>=StartScn日志文件部分
EndScn              数字型(Number)                 分析重作日志中SCN<=EndScn日志文件部分
StartTime           日期型(Date)                 分析重作日志中时间戳>=StartTime的日志文件部分
EndTime             日期型(Date)                 分析重作日志中时间戳<=EndTime的日志文件部分
DictFileName        字符型(VARCHAR2)                 字典文件,该文件包含一个数据库目录的快照。使用该文件可以使得到的分析结果是可以理解的文本形式,而非系统内部的16进制
Options        INARY_INTEGER         0        系统调试参数,实际很少使用
例如我没只需要分析2010年12月1日0点-2006年12月1日15点之间的日志4.观察分析结果(v$logmnr_contents)
到现在为止,我们已经分析得到了重作日志文件中的内容。动态性能视图v$logmnr_contents包含LogMiner分析得到的所有的信息。


如果我们仅仅想知道某个用户对于某张表的操作,可以通过下面的SQL查询得到,该查询可以得到对表JB.AA01所作的一切工作。
需要强调一点的是,视图v$logmnr_contents中的分析结果仅在我们运行过程'dbms_logmrn.start_logmnr'这个会话的生命期中存在。这是因为所有的LogMiner存储都在PGA内存中,所有其他的进程是看不到它的,同时随着进程的结束,分析结果也随之消失。
最后,使用过程DBMS_LOGMNR.END_LOGMNR终止日志分析事务,此时PGA内存区域被清除,分析结果也随之不再存在。



上一篇:oracle cluster verification utility 错误
下一篇:新oracle 是执行dbca,显示没有命令??
回复

使用道具 举报

1框架
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表