格式:

alter system|session set events ‘[eventnumber|immediate] trace name eventname [forever] [level levelnumber] :  …….’
 

通过:符号,可以连续设置多个事件,也可以通过连续使用alter session set events来设置多个事件。

格式说明:

eventnumber指触发dump的事件号,事件号可以是Oracle错误号(出现相应错误时跟踪指定的事件)或oralce内部事件号,内部事件号在10000到10999之间,不能与immediate关键字同用。

immediate关键字表示命令发出后,立即将指定的结构dump到跟踪文件中,这个关键字只用在alter session语句中,并且不能与eventnumber、forever关键字同用。

trace name是关键字


eventname指事件名称(见后面),即要进行dump的实际结构名。若eventname为context,则指根据内部事件号进行跟踪。


forever关键字表示事件在实例或会话的周期内保持有效状态,不能与immediate同用。


level为事件级别关键字。但在dump错误栈(errorstack)时不存在级别。


levelnumber表示事件级别号,一般从1到10,1表示只dump结构头部信息,10表示dump结构的所有信息。

常用转储命令:

一.Memory Dumps
1).Global Area 
Alter SESSION SET EVENTS 'immediate trace name global_area level n'; 
1 包含PGA 
2 包含SGA 
4 包含UGA 
8 包含indrect memory


2).Library Cache 
Alter SESSION SET EVENTS 'immediate trace name library_cache level n'; 
1 library cache统计信息 
2 包含hash table histogram 
3 包含object handle 
4 包含object结构(Heap 0)


3).Row Cache 
Alter SESSION SET EVENTS 'immediate trace name row_cache level n'; 
1 row cache统计信息 
2 包含hash table histogram 
8 包含object结构


4).Buffers 
Alter SESSION SET EVENTS 'immediate trace name buffers level n'; 
1 buffer header 
2 level 1 + block header 
3 level 2 + block contents 
4 level 1 + hash chain 
5 level 2 + hash chain 
6 level 3 + hash chain 
8 level 4 + users/waiters 
9 level 5 + users/waiters 
10 level 6 + users/waiters


5).Buffer 
Alter SESSION SET EVENTS 'immediate trace name buffer level n'; 
n为某个指定block的rdba,该命令可以转储某个block在buffer中的所有版本。


6).Heap 
Alter SESSION SET EVENTS 'immediate trace name heapdump level level'; 
1 PGA摘要 
2 SGA摘要 
4 UGA摘要 
8 Current call(CGA)摘要 
16 User call(CGA)摘要 
32 Large call(LGA)摘要 
1025 PGA内容 
2050 SGA内容 
4100 UGA内容 
8200 Current call内容 
16400 User call内容 
32800 Large call内容


7).Sub Heap 
oracle 9.0.1版本之前 
Alter SESSION SET EVENTS 'immediate trace name heapdump_addr level n'; 
若n为subheap的地址,转储的是subheap的摘要信息 
若n为subheap的地址+1,转储的则是subheap的内容 
oracle 9.2.0版本之后 
Alter SESSION SET EVENTS 'immediate trace name heapdump_addr level n, addr m'; 
其中m为subheap的地址 
n为1转储subheap的摘要,n为2转储subheap的内容


8).Process State 
Alter SESSION SET EVENTS 'immediate trace name processstate level n';


9).System State 
Alter SESSION SET EVENTS 'immediate trace name systemstate level n';


10).Error State 
Alter SESSION SET EVENTS 'immediate trace name errorstack level n'; 
0 Error stack 
1 level 0 + function call stack 
2 level 1 + process state 
3 level 2 + context area


11).Hang Analysis 
Alter SESSION SET EVENTS 'immediate trace name hanganalyze level n';


12).Work Area 
Alter SESSION SET EVENTS 'immediate trace name workareatab_dump level n'; 
1 SGA信息 
2 Workarea Table摘要信息 
3 Workarea Table详细信息


13).Latches 
Alter SESSION SET EVENTS 'immediate trace name latches level n'; 
1 latch信息 
2 统计信息


14).Events 
Alter SESSION SET EVENTS 'immediate trace name events level n'; 
1 session 
2 process 
3 system


15).Locks 
Alter SESSION SET EVENTS 'immediate trace name locks level n';


16).Shared Server Process 
Alter SESSION SET EVENTS 'immediate trace name shared_server_state level n'; 
n取值为1~14


17).Background Messages 
Alter SESSION SET EVENTS 'immediate trace name bg_messages level n'; 
n为pid+1


二.File Dumps
1).Block 
oracle 7之前 
Alter SESSION SET EVENTS 'immediate trace name blockdump level n'; 
n为block的rdba 
oracle8以后 
Alter SYSTEM DUMP DATAFILE file# BLOCK block#; 
Alter SYSTEM DUMP DATAFILE file# 
BLOCK MIN minimum_block# 
BLOCK MAX maximum_block#;


2).Tree Dump   查看索引的结构
Alter SESSION SET EVENTS 'immediate trace name treedump level n'; 
n为object_id

object_id可以从select object_id from user_objects where object_name = '索引的名字'得到。


3).Undo Segment Header  查看回滚段头部信息
Alter SYSTEM DUMP UNDO_HEADER 'segment_name';


4).Undo for a Transaction 
Alter SYSTEM DUMP UNDO BLOCK 'segment_name' XID xidusn xidslot xidsqn;


5).File Header 
Alter SESSION SET EVENTS 'immediate trace name file_hdrs level n'; 
1 文件头信息
2 level 1 + 文件头信息 
3 level 2 + 数据文件头信息 
10 level 3


6).Control file 
Alter SESSION SET EVENTS 'immediate trace name controlf level n'; 
1  控制文件中的文件头信息
2 level 1 + 数据库信息 + 检查点信息 
3 level 2 + 可重用节信息 
10 level 3


7).Redo log Header 
Alter SESSION SET EVENTS 'immediate trace name redohdr level n'; 
1 控制文件中的redo log信息 
2 level 1 + 文件头信息 
3 level 2 + 日志文件头信息 
10 level 3


8).Redo log 
Alter SYSTEM DUMP LOGFILE 'FileName'; 
Alter SYSTEM DUMP LOGFILE 'FileName' 
SCN MIN MinimumSCN 
SCN MAX MaximumSCN 
TIME MIN MinimumTime 
TIME MAX MaximumTime 
LAYER Layer 
OPCODE Opcode 
DBA MIN FileNumber . BlockNumber 
DBA MAX FileNumber . BlockNumber 
RBA MIN LogFileSequenceNumber . BlockNumber 
RBA MAX LogFileSequenceNumber . BlockNumber; 
其中time = (((((yyyy - 1988)) * 12 + mm - 1) * 31 + dd - 1) * 24 + hh) * 60 + mi) * 60 + ss;

9).Loghist 
Alter SESSION SET EVENTS 'immediate trace name loghist level n'; 
1 dump控制文件中最早和最迟的日志历史项 
>1 dump 2^n个日志历史项


三、事件导出应用举例(有篇文章《ORACLE 内部事件号》关于事件专门列举出事件号供参考):

ALTER   SYSTEM   SET   EVENTS   ‘10231   trace   name   context   forever,level   10


实际应用:
例:shutdown immdiate关闭数据库,然后在mount状态转储获得控制文件内容:

1、

SQL>shutdown immediate;
SQL
>starup mount;
SQL
>alter session set events 'immediate trace name CONTROLF level 12';

2、get trc name:

SELECT    a.VALUE
       
|| b.symbol
       
|| c.instance_name
       
|| '_ora_'
       
|| d.spid
       
|| '.trc' trace_file
  
FROM (SELECT VALUE
          
FROM v$parameter
         
WHERE NAME = 'user_dump_dest') a,
       (
SELECT SUBSTR (VALUE, -61) symbol
          
FROM v$parameter
         
WHERE NAME = 'user_dump_dest') b,
       (
SELECT instance_name
          
FROM v$instance) c,
       (
SELECT spid
          
FROM v$session s, v$process p, v$mystat m
         
WHERE s.paddr = p.addr AND s.SID = m.SID AND m.statistic# = 0) d
/


TRACE_FILE
----------------------------------------------------------------------------------------------------
/u01/app/oracle/admin/oralin/udump/oralin_ora_18186.trc


3、打开显示的trc文件,查看控制文件的详细内容。

转自:http://www.cnblogs.com/vegaslee/archive/2009/09/03/1559350.html

参考资料:

Oracle数据库event事件与dump文件介绍-入门基础 http://www.bitscn.com/pdb/oracle/200811/154490.html

alter system set events相关知识  http://blog.chinaunix.net/u/12521/showart_1983196.html