Oracle logminer 分析redo log(TOAD与PLSQL)
Oracle logminer 分析redo log
Oracle 11g r2 RAC centos 6.5
设置时间格式
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') date_format from dual ;
查看数据库是否开启补全日志功能
select
SUPPLEMENTAL_LOG_DATA_MIN,
SUPPLEMENTAL_LOG_DATA_PK,
SUPPLEMENTAL_LOG_DATA_UI,
SUPPLEMENTAL_LOG_DATA_FK,
SUPPLEMENTAL_LOG_DATA_ALL from v$database;
开启补全日志
alter database add supplemental log data;
alter database add supplemental log data (primary key, unique,foreign key) columns;
再次查询检查是否开启
开启归档--详细见归档的开启
SQL> archive log list;
Database log mode Archive Mode
Automatic archival Enabled
Archive destination +FRA/bol/arch
Oldest online log sequence 93
Next log sequence to archive 95
Current log sequence 95
配置LogMiner工具
SQL> show parameter UTL_FILE
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
utl_file_dir string
1 利用toad自带的工具logminer
dml 操作
select *from TESTYHQ;
insert into TESTYHQ(id1,name1)values (2,'hq');
commit;
利用toad的logminer直接分析redo
select * from V$LOGFILE;
select group#,sequence#,bytes,members,status from v$log;
toad-database-diagnose-logminer
选择online logs,输入redo文件全路径,比如
+DATA/bol/onlinelog/group_2.258.990861405
再选择时间范围,选择过大的话,日志会有很多,完成后点击finish,直接生成记录
可以用sql进行筛选查看
select scn,timestamp,operation,seg_owner,seg_name,
table_space,row_id,username,os_username,machine_name,
session#,serial#,sql_redo,sql_undo from v$logmnr_contents where seg_owner='SDE';
几个关键字段,username,machine_name,session#,serial#,sql_redo,sql_undo,可以清楚的看见
scn,时间,操作内容,表名,操作的机器名字,和操作语句,以及undo内容
2 利用plsql进行分析
[root@rac1 /]# mkdir u02
[root@rac1 /]# chown oracle:oinstall /u02
alter system set utl_file_dir='/u02' scope=spfile; --需要重启db
SQL> show parameter UTL_FILE
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
utl_file_dir string /u02
[root@rac1 admin]# ls dbmslm*
dbmslmd.sql dbmslm.sql dbmslms.sql
[root@rac1 admin]# pwd
/u01/app/11.2.0/grid/rdbms/admin
SQL> @/u01/app/11.2.0/grid/rdbms/admin/dbmslmd.sql
SQL> @/u01/app/11.2.0/grid/rdbms/admin/dbmslm.sql
SQL> @/u01/app/11.2.0/grid/rdbms/admin/dbmslms.sql
SQL> execute dbms_logmnr_d.build(dictionary_filename =>'dfdict.data',dictionary_location =>'/u02');
PL/SQL procedure successfully completed.
--- 如果报错,请检查目录及权限
*
ERROR at line 1:
ORA-01336: specified dictionary file cannot be opened
ORA-29283: invalid file operation
ORA-06512: at "SYS.UTL_FILE", line 536
ORA-29283: invalid file operation
ORA-06512: at "SYS.DBMS_LOGMNR_INTERNAL", line 6110
ORA-06512: at "SYS.DBMS_LOGMNR_INTERNAL", line 6200
ORA-06512: at "SYS.DBMS_LOGMNR_D", line 12
ORA-06512: at line 1
--
insert into TESTYHQ(id1,name1)values (444,'hq');
commit;
select group#,sequence#,bytes,members,status from v$log;
select * from V$LOGFILE;
SQL> alter system switch logfile;
----
因为这里只有一个日志,那么只需要添加一个就好了(第一个日志用new“=>dbms_logmnr.new”)
execute dbms_logmnr.add_logfile(options =>dbms_logmnr.new,logfilename =>'/u01/app/oracle/oradata/or11g/redo01.log');
如果是有多个日志,那么就继续添加(添加其他日志用add“=>dbms_logmnr.addfile”):
execute dbms_logmnr.add_logfile(options =>dbms_logmnr.addfile,logfilename=>'/u01/app/oracle/oradata/or11g/redo02.log');
dbms_logmnr.new --用于建一个日志分析表
dbms_logmnr.addfile --用于加,入用于分析的日志文件
dbms_logmnr.removefile --用于移出,用于分析的日志文件
如果是删除日志就用removefile,如:
execute dbms_logmnr.add_logfile(options =>dbms_logmnr.removefile,logfilename =>'/u01/app/oracle/oradata/or11g/redo03.log');
---
SQL> alter system switch logfile;
System altered.
SQL> exec dbms_logmnr.add_logfile('+DATA/bol/onlinelog/group_1.257.990861405',dbms_logmnr.new);
PL/SQL procedure successfully completed.
SQL> exec dbms_logmnr.start_logmnr(dictfilename=>'/u02/dfdict.data');
PL/SQL procedure successfully completed.
select scn,timestamp,operation,seg_owner,seg_name,
table_space,row_id,username,os_username,machine_name,
session#,serial#,sql_redo,sql_undo from v$logmnr_contents where seg_owner='SDE';
create table t01 as select scn,timestamp,operation,seg_owner,seg_name,
table_space,row_id,username,os_username,machine_name,
session#,serial#,sql_redo,sql_undo from v$logmnr_contents where seg_owner='SDE';
--v$logmnr_contents 针对于session,其他session执行该查询就会报错
ORA-01306: 在从 v$logmnr_contents 中选择之前必须调用 dbms_logmnr.start_logmnr()
select *from t01;
SQL> exec dbms_logmnr.end_logmnr;--关闭日志挖掘
PL/SQL procedure successfully completed.
select *from t01;
Oracle logminer 分析redo log(TOAD与PLSQL)的更多相关文章
- Oracle Logminer 分析重做日志RedoLog和归档日志ArchiveLog
在实际开发过程中,有时我们很有可能需要某个表的操作痕迹,或通过记录的SQL语句进行有目的性的数据恢复(此时POINT-IN-TIME恢复已经满足不了更细的粒度).或仅仅是查看: 据说Oracle8i之 ...
- Oracle Dataguard Standby Redo Log的两个实验
在Data Guard环境中,Standby Redo Log是一个比较特殊的日志类型.从最新的DG安装指导中,都推荐在Primary和Standby端,都配置Standby Redo Log. 简单 ...
- Oracle 11g的Redo Log和Archive Log的分析方法
自Oracle 11g起,无需设置UTL_FILE_DIR就可以使用LOGMNR对本地数据库的日志进行分析,以下是使用LOGMNR的DICT_FROM_ONLINE_CATALOG分析REDO和归档日 ...
- LOGMNR分析redo log和archive log教程
自Oracle 11g起,无需设置UTL_FILE_DIR就可以使用LOGMNR对本地数据库的日志进行分析,以下是使用LOGMNR的DICT_FROM_ONLINE_CATALOG分析REDO和归档日 ...
- Oracle Redo Log 机制 小结(转载)
Oracle 的Redo 机制DB的一个重要机制,理解这个机制对DBA来说也是非常重要,之前的Blog里也林林散散的写了一些,前些日子看老白日记里也有说明,所以结合老白日记里的内容,对oracle 的 ...
- 1、图解Oracle Logminer配置使用
LogMiner配置使用手册 1 Logminer简介 1.1 LogMiner介绍 Oracle LogMiner 是Oracle公司从产品8i以后提供的一个实际非常有用的分析工具,使用该工具可以轻 ...
- DBA_Oracle LogMiner分析重做和归档日志(案例)
2014-08-19 Created By BaoXinjian
- [Oracle]LogMiner工具小结
(一)LogMiner工具的作用Logminer工具主要用来分析redo log和archive log文件.通过该工具,可以轻松获得Oracle redo log和archive log文件的具体内 ...
- 总结:基于Oracle Logminer数据同步
第 1 页 共 20 页 出自石山园主,博客地址:http://www.cnblogs.com/shishanyuan LogMiner 配置使用手册 1 Logminer 简介 1.1 LogMin ...
随机推荐
- JSP 导出Excel表格
ES6语法 传入一个table的id,然后在导出excel按钮上加入一个<a href="#" id="buttonId">导出Excel</ ...
- Struts2的Action中访问servletAPI方式
struts2的数据存放中心为ActionContext,其是每次请求来时都会创建一个ActionContext,访问结束销毁,其绑定在ThreadLocal上,由于每次访问web容器都会为每次请求创 ...
- 【bzoj1876】[SDOI2009]SuperGCD(高精度)
题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=1876 一道简单的高精度+Stein算法(或者叫辗转相除法)求最大公约数板子题. md还 ...
- javascript语言历史
起初,web站点事实上只不过是一个静态的HTML文档集,这些文档之间仅依靠一些简单的超链接(Hyperlinks)绑定在一起. 但很快,随着Web业务的快速普及和增长,网站管理者越来越希望自己所创建的 ...
- 19条ANDROID平台设计规范平台设计规范
1.尺寸以及分辨率: Android的界面尺寸比较流行的有:480*800.720*1280.1080*1920,我们在做设计图的 时候建议是以 480*800的尺寸为标准: 2.界面基本组成元素: ...
- poj 1300 欧拉图
http://poj.org/problem?id=1300 要不是书上有翻译我估计要卡死,,,首先这是一个连通图,鬼知道是那句话表示出来的,终点必须是0,统计一下每个点的度数,如果是欧拉回路那么起点 ...
- EDID真实数据块,请参考标准文档仔细核对
数据格式的详细说明:http://en.wikipedia.org/wiki/Extended_display_identification_data 下面是一个例子:
- tableau join 与格式问题
一开始我没有找到它的join 方法.其实应该是编辑相应的join关系.选择数据源,选择字段.数据源是可以选择的. 剩下的计算问题,要再弄下.不好说,这个其实烦了我很久了. 高级选项,扩展最大行数.即可 ...
- 解决让浏览器兼容ES6特性
为什么ES6会有兼容性问题? 由于广大用户使用的浏览器版本在发布的时候也许早于ES6的定稿和发布,而到了今天,我们在编程中如果使用了ES6的新特性,浏览器若没有更新版本,或者新版本中没有对ES6的特性 ...
- nyoj-3-多边形重心问题(求多边形面积和中心)
题目链接 /* Name:nyoj-3-多边形重心问题 Copyright: Author: Date: 2018/4/26 21:25:41 Description: ACM国际大学生程序设计竞赛 ...