logmnr日志解析

1、logmnr日志解析
    (1)开启最小附加日志
 (2)安装logmnr
 (3)logminer工具使用
 
如果需要Logminer解析日志的DDL以及DML内容,需要确保源数据库在产生redo或者归档日志前已开启最小附加日志。
一、开启最小附加日志
SELECT SUPPLEMENTAL_LOG_DATA_PK, SUPPLEMENTAL_LOG_DATA_UI FROM V$DATABASE;
alter database add supplemental log data(primary key,unique index) columns;
SELECT SUPPLEMENTAL_LOG_DATA_PK, SUPPLEMENTAL_LOG_DATA_UI FROM V$DATABASE;
二、安装logmnr
以sysdba用户执行3个脚本
@?/rdbms/admin/dbmslm.sql
@?/rdbms/admin/dbmslmd.sql
@?/rdbms/admin/dbmslms.sql
三、Logminer工具使用
3.1 使用在线联机日志(online_catalog)
适用环境:在源数据库本地做日志解析
1、添加日志列表
首个日志
exec dbms_logmnr.add_logfile('/u01/arch/1_18_992364482.dbf',options=>dbms_logmnr.new);
第N个日志
exec dbms_logmnr.add_logfile('/u01/arch/1_19_992364482.dbf', dbms_logmnr.ADDFILE);
2、日志解析
使用当前redo作为数据字典
 exec dbms_logmnr.start_logmnr(options=>dbms_logmnr.dict_from_online_catalog);
3、将日志解析内容做存档
 create table log_all as select * from v$logmnr_contents;
4、分析日志
按用户以及表名分析日志
 select to_char(timestamp,'yyyy-mm-dd hh24:mi:ss'),sql_redo,sql_undo from v$logmnr_contents where username='SCOTT' and table_name='HOEGH';
5、结束日志分析
  exec dbms_logmnr.end_logmnr();
posted @ 2021-02-26 15:43  xiewg  阅读(434)  评论(0编辑  收藏  举报