--查看日志文件
select member from v$logfile;
--查看表空間使用情況
SELECT SUM(bytes) / (1024 * 1024) AS free_space, tablespace_name
FROM dba_free_space
GROUP BY tablespace_name;
SELECT a.tablespace_name,
a.bytes total,
b.bytes used,
c.bytes free,
(b.bytes * 100) / a.bytes "% USED ",
(c.bytes * 100) / a.bytes "% FREE "
FROM sys.smts_used b, sys.sm$ts_free c
WHERE a.tablespace_name = b.tablespace_name
AND a.tablespace_name = c.tablespace_name;
--查看回滾段名稱及大小
SELECT segment_name,
tablespace_name,
r.status,
(initial_extent / 1024) initialextent,
(next_extent / 1024) nextextent,
max_extents,
v.curext curextent
FROM dba_rollback_segs r, v$rollstat v
WHERE r.segment_id = v.usn(+)
ORDER BY segment_name;
Oracle日志查看
一.Oracle日志的路徑:
登錄:sqlplus "/as sysdba"
查看路徑:SQL> select * from v$logfile;
SQL> select * from v$logfile;(#日志文件路徑)
二.Oracle日志文件包含哪些內(nèi)容:(日志的數(shù)量可能略有不同)
control01.ctl example01.dbf redo02.log sysaux01.dbf undotbs01.dbf
control02.ctl redo03.log system01.dbf users01.dbf
control03.ctl redo01.log SHTTEST.dbf temp01.dbf
三.Oracle日志的查看方法:
SQL>select * from v$sql (#查看最近所作的操作)
SQL>select * fromv $sqlarea(#查看最近所作的操作)
Oracle 數(shù)據(jù)庫(kù)的所有更改都記錄在日志中,從目前來(lái)看澡屡,分析Oracle日志的唯一方法就是使用Oracle公司提供的LogMiner來(lái)進(jìn)行锣险,因?yàn)樵嫉娜罩拘畔⑽覀兏緹o(wú)法看懂,Oracle8i后續(xù)版本中自帶了LogMiner,而LogMiner就是讓我們看懂日志信息的工具,通過這個(gè)工具可以:查明數(shù)據(jù)庫(kù)的邏輯更改冶伞,偵察并更正用戶的誤操作,執(zhí)行事后審計(jì),執(zhí)行變化分析庐冯。
四.LogMiner的使用:
1高氮、創(chuàng)建數(shù)據(jù)字典文件(data-dictionary)
1).首先在init.ora初始化參數(shù)文件中慧妄,添加一個(gè)參數(shù)UTL_FILE_DIR,該參數(shù)值為服務(wù)器中放置數(shù)據(jù)字典文件的目錄剪芍。如:UTL_FILE_DIR = ($ORACLE_HOME\logs) ,重新啟動(dòng)數(shù)據(jù)庫(kù)塞淹,使新加的參數(shù)生效:
SQL> shutdown;
SQL>startup;
2).然后創(chuàng)建數(shù)據(jù)字典文件
SQL> connect /as sysdba
SQL> execute dbms_logmnr_d.build(dictionary_filename => 'dict.ora',dictionary_location => '/data1/oracle/logs');
PL/SQL procedure successfully completed
2、創(chuàng)建要分析的日志文件列表
1).創(chuàng)建分析列表罪裹,即所要分析的日志
SQL>execute dbms logmnr.add logfile(LogFileName => '/data1/oracle/oradata/akazamdb/redo01.log',Options => dbms_logmnr.new);
PL/SQL procedure successfully completeds
2).添加分析日志文件饱普,一次添加1個(gè)為宜
SQL>execute dbms_ logmnr.add_ logfile(LogFileName => '/data1/oracle/oradata/akazamdb/redo01.log',Options => dbms_logmnr.ADDFILE);
PL/SQL procedure successfully completed
3运挫、使用LogMiner進(jìn)行日志分析(具體要查詢什么內(nèi)容可以自己修改)
(1)無(wú)限制條件
SQL> EXECUTE dbms_logmnr.start_logmnr(
DictFileName=>'/data1/oracle/logs/v816dict.ora ');
(2)有限制條件
通過對(duì)過程DBMS_ LOGMNR.START_LOGMNR中幾個(gè)不同參數(shù)的設(shè)置,可以縮小要分析日志文件的范圍套耕。通過設(shè)置起始時(shí)間和終止時(shí)間參數(shù)我們可以限制只分析某一時(shí)間范圍的日志谁帕。如下面的例子,我們僅僅分析2007年9月18日的日志:
SQL> EXECUTE dbms_logmnr.start_logmnr(
DictFileName => ' /data1/oracle/logs/ v816dict.ora ',
StartTime => to_date('2007-9-18 00:00:00','YYYY-MM-DD HH24:MI:SS')
EndTime => to_date(''2007-9-18 23:59:59','YYYY-MM-DD HH24:MI:SS '));
也可以通過設(shè)置起始SCN和截至SCN來(lái)限制要分析日志的范圍:
SQL> EXECUTE dbms_logmnr.start_logmnr(
DictFileName => ' /data1/oracle/logs/ v816dict.ora ',
StartScn => 20,
EndScn => 50);
4冯袍、觀察分析結(jié)果(vlogmnr_contents包含LogMiner分析得到的所有的信息康愤。
SELECT sql_redo FROM vlogmnr_contents WHERE username='DB_ZGXT' AND tablename='SB_DJJL';
需要強(qiáng)調(diào)一點(diǎn)的是贮折,視圖v$logmnr_contents中的分析結(jié)果僅在我們運(yùn)行過程'dbms_logmrn.start_logmnr'這個(gè)會(huì)話的生命期中存在。這是因?yàn)樗械腖ogMiner存儲(chǔ)都在PGA內(nèi)存中资盅,所有其他的進(jìn)程是看不到它的调榄,同時(shí)隨著進(jìn)程的結(jié)束,分析結(jié)果也隨之消失呵扛。
最后每庆,使用過程DBMS_LOGMNR.END_LOGMNR終止日志分析事務(wù),此時(shí)PGA內(nèi)存區(qū)域被清除今穿,分析結(jié)果也隨之不再存在缤灵。
5、查看LogMiner工具分析結(jié)果
SQL> select * from dict t where t.table_name like '%LOGMNR%';-看所有與logmnr相關(guān)的視圖
TABLE_NAME COMMENTS
GVLOGMNR_CALLBACK
GVLOGMNR_CONTENTS
GVLOGMNR_DICTIONARY
GVLOGMNR_LOGFILE
GVLOGMNR_LOGS
GVLOGMNR_PARAMETERS
GVLOGMNR_PROCESS
GVLOGMNR_REGION
GVLOGMNR_SESSION
GVLOGMNR_STATS
GVLOGMNR_TRANSACTION
VLOGMNR_CALLBACK
VLOGMNR_CONTENTS
VLOGMNR_DICTIONARY
VLOGMNR_LOGFILE
VLOGMNR_LOGS
VLOGMNR_PARAMETERS
VLOGMNR_PROCESS
VLOGMNR_REGION
VLOGMNR_SESSION
TABLE_NAME COMMENTS
VLOGMNR_STATS
VLOGMNR_TRANSACTION
GVLOGMNR_CONTENTS 視圖中蓝晒,可按以下語(yǔ)句查詢:
select scn,timestamp,log_id,seg_owner,seg_type,table_space,data_blk#,data_obj#,data_objd#,
session#,serial#,username,session_info,sql_redo,sql_undo from logmnr3 t where t.sql_redo like 'create%';
如果不能正常查詢GVlogmnr_contents 中選擇之前必須調(diào)用 dbms_logmnr.start_logmnr() 芝薇∨叱埃可e799bee5baa6e79fa5e98193e59b9ee7ad9431333337393535采用如下方法:
create table logmnr3 as select * from GV$LOGMNR_CONTENTS;
Oracle端口:1521