使用Oracle 10g的Logminer挖掘日誌
Logminer是oracle從8i開始提供的用於分析重做日誌資訊的工具,它包括DBMS_LOGMNR和DBMS_LOGMNR_D兩個package,後邊的D是字典的意思。它既能分析redo log file,也能分析歸檔後的archive log file。在分析日誌的過程中需要使用資料字典,一般先生成資料字典檔案後使用,10g版本還可以使用線上資料字典。
Logminer可以分析其它資料庫的重做日誌檔案,但是必須使用重做日誌所在資料庫的資料字典,否則會出現無法識別的亂碼。另外被分析資料庫的作業系統平臺最好和當前Logminer所在資料庫的執行平臺一樣,且block size相同。
1、執行以下2個指令碼安裝logminer功能,一般資料庫都已經安裝好了:
[@more@]ls -l dbmsl*
-rw-r--r-- 1 oracle oinstall 17246 Oct 27 2006 dbmslm.sql
-rw-r--r-- 1 oracle oinstall 4663 Oct 27 2006 dbmslmd.sql
2、要生成資料字典檔案,首先要修改一個utl_file_dir引數,修改為*或者想存放資料字典檔案位置的目錄:
SQL> show parameter utl_file_dir
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
utl_file_dir stringSQL> alter system set utl_file_dir='*' scope=spfile;
System altered.
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.
3、生成資料字典檔案
SQL> show parameter utl_file_dir
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
utl_file_dir string *
SQL> EXECUTE dbms_logmnr_d.build(dictionary_filename => 'dict20090625.dat',dictionary_location => '/orabak');PL/SQL procedure successfully completed.
4、可以先設定使用的表空間
SQL> EXECUTE DBMS_LOGMNR_D.SET_TABLESPACE('erp')
PL/SQL procedure successfully completed.
5、填加要分析的日誌檔案
SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE(LogFileName=>'/orabak/testarch/1_89802_640266118.dbf',Options=>dbms_logmnr.new);
PL/SQL procedure successfully completed.
6、可以繼續填加,用dbms_logmnr.removefile可以刪除
SQL> EXECUTE DBMS_LOGMNR.ADD_LOGFILE(LogFileName=>'/orabak/testarch/1_89807_640266118.dbf',Options=>dbms_logmnr.addfile);
PL/SQL procedure successfully completed.
7、開始分析日誌
SQL> execute dbms_logmnr.start_logmnr(dictfilename=>'/orabak/dict20090625.dat');
PL/SQL procedure successfully completed.
提取特定時間的日誌:
dbms_logmnr.start_logmnr(dictfilename=>'/orabak/dict20090625.dat',
starttime=>to_date('2009-06-24 09:30:00','YYYY-MM-DD HH24:MI:SS'),
endtime=>to_date('2009-06-24 12:00:59','YYYY-MM-DD HH24:MI:SS'))
使用線上資料字典:
SQL> EXEC DBMS_LOGMNR.START_LOGMNR(OPTIONS => DBMS_LOGMNR.DICT_FROM_ONLINE_CATALOG);
PL/SQL procedure successfully completed.
8、檢視結果
select timestamp,username,session#,sql_redo,operation from v$logmnr_contents;
9、結束分析,釋放PGA記憶體資源
SQL> exec dbms_logmnr.end_logmnr;
PL/SQL procedure successfully completed.
注意,v$logmnr_contents內容儲存了日誌的內容,只在當前會話有效,如果想長期儲存分析,可以在當前會話用create table tablename as select * from v$logmnr_contents語句來持久儲存。
另外一個windows環境的測試:
SQL> desc v$logmnr_logs;
名稱 是否為空? 型別
----------------------------------------- --------
LOG_ID NUMBER
FILENAME VARCHAR2(512)
LOW_TIME DATE
HIGH_TIME DATE
DB_ID NUMBER
DB_NAME VARCHAR2(8)
RESET_SCN NUMBER
RESET_SCN_TIME DATE
THREAD_ID NUMBER
THREAD_SQN NUMBER
LOW_SCN NUMBER
NEXT_SCN NUMBER
DICTIONARY_BEGIN VARCHAR2(3)
DICTIONARY_END VARCHAR2(3)
TYPE VARCHAR2(7)
BLOCKSIZE NUMBER
FILESIZE NUMBER
INFO VARCHAR2(32)
STATUS NUMBERSQL> select filename from v$logmnr_logs;
FILENAME
--------------------------------------------------------------------------------
E:ORACLEPRODUCT10.2.0DB_2DATABASEDB_RECOVERY_FILE_DESTARC26_666280390_1
E:ORACLEPRODUCT10.2.0DB_2DATABASEDB_RECOVERY_FILE_DESTARC27_666280390_1SQL> select log_id,low_scn,low_time,next_scn,high_time from v$logmnr_logs;
LOG_ID LOW_SCN LOW_TIME NEXT_SCN HIGH_TIME
---------- ---------- ------------------- ---------- -------------------
26 1576118 2008/09/26 12:56:37 1580527 2008/09/26 13:15:02
27 1580527 2008/09/26 13:15:02 1580563 2008/09/26 13:16:04SQL> exec dbms_logmnr.start_logmnr(dictfilename=>'E:logmnrdict.ora',startscn=>1576118,endscn=>1580563);
SQL> select scn,timestamp , sql_redo from v$logmnr_contents where seg_owner='TEST' and seg_name='TT';
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/678020/viewspace-1043026/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- ORACLE的日誌挖掘 logminerOracle
- ORACLE logminer 日誌挖掘Oracle
- 使用Oracle的logminer工具進行日誌挖掘Oracle
- Logminer日誌挖掘
- logminer日誌挖掘技術
- oracle 11g logminer 進行日誌挖掘Oracle
- logminer日誌挖掘操作步驟
- logminer異機挖掘歸檔日誌
- 從Logminer日誌挖掘中找出可疑的操作
- Oracle 10g LOGMNR挖掘日誌很方便Oracle 10g
- 使用 Oracle logminer 挖掘日誌恢復誤刪資料以及查詢操作者Oracle
- ORACLE LOGMNR 日誌挖掘Oracle
- oracle 10g中logminer的使用Oracle 10g
- Oracle11g使用LOGMNR挖掘日誌Oracle
- 使用日誌挖掘來挖掘TX等待的事務
- 動手為王——利用logminer挖掘日誌恢復誤操作
- 日誌挖掘
- LOGMINER日誌分析
- 日誌挖掘的方法
- 使用logminer分析歸檔日誌案例
- oracle 9i logminer日誌分析01Oracle
- oracle logminer分析線上 離線日誌方法Oracle
- 利用oracle的日誌挖掘實現回滾Oracle
- oracle 10g logminerOracle 10g
- 日誌挖掘-對於DML操作的挖掘
- logminer 日誌分析案例
- logminer抽取日誌案例
- 【REDO】Oracle 日誌挖掘,分析歸檔日誌線上日誌主要步驟Oracle
- 日誌分析logmnr (Logminer) 使用方法
- 使用Logminer來分析具體的DML操作日誌
- 日誌挖掘-對於DDL語句的挖掘
- logminr 日誌挖掘
- logmnr 日誌挖掘
- 日誌挖掘 log miner
- 歸檔日誌挖掘
- 使用LOG Miner挖掘日誌基本步驟
- oracle 10g 歸檔日誌Oracle 10g
- 在oracle中Logmnr進行日誌挖掘Oracle