Chinaunix首页 | 论坛 | 博客
  • 博客访问: 602897
  • 博文数量: 51
  • 博客积分: 4000
  • 博客等级: 上校
  • 技术积分: 1737
  • 用 户 组: 普通用户
  • 注册时间: 2006-06-27 13:45
文章分类

全部博文(51)

文章存档

2011年(3)

2009年(19)

2008年(29)

我的朋友

分类: Oracle

2008-04-15 22:46:36

10046事件的说明和使用
 10046事件是oracle内部事件,是sql_trace的增强
 1、设置级别
    level 1      启用标准的sql_trace的功能  等价于sql_trace
    level 4      等价于level 1 +  邦定值
    level 8      等价于level 1 + 等待事件跟踪
    level 12     等价于level 1 + level 4 + level 8
 2、全局设置
    在参数文件spfile 中加入 event="10046 trace name context forever, level 12 "
 3、session 中设置
    SQL> SQL> alter session set events'10046 trace name context forever ';
    SQL> alter session set events'10046 trace name context forever , level 12 ';
    SQL> alter session set events '10046 trace name context off ';
 4、对其它用户session设置
    通过dbms_system.set_ev 系统包来实现
    SQL> desc dbms_system
    ......
 PROCEDURE SET_EV
 Argument Name                  Type                    In/Out Default?
 ------------------------------ ----------------------- ------ --------
 SI                             BINARY_INTEGER          IN
 SE                             BINARY_INTEGER          IN
 EV                             BINARY_INTEGER          IN
 LE                             BINARY_INTEGER          IN
 NM                             VARCHAR2                IN
 
 其中SI、SE来之v$session
 查询获得需要跟踪的session信息
 SQL> select sid ,serial# , username from v$session where username is not null;
       SID    SERIAL# USERNAME
---------- ---------- ------------------------------
       302        619 SYS
       315       1545 SYS
       335       2373 SYS
 执行跟踪
  SQL> exec dbms_system.set_ev(302,619,10046,12,'sys');
  PL/SQL procedure successfully completed. 
结束跟踪
  SQL> exec dbms_system.set_ev(302,619,10046,0,'sys');
  PL/SQL procedure successfully completed.
查找跟踪文件
 select d.value||'/'||lower(rtrim(i.instance,chr(0)))||'_ora_'||p.spid||'.trc' trace_file_name
 from                         
 (select p.spid
 from sys.v$mystat m , sys.v$session s ,v$process p
 where m.statistic#= 1 and s.sid=m.sid and p.addr=s.paddr) p,
 (select  t.instance from sys.v$thread t , sys.v$parameter v
 where v.name = 'thread' and (v.value=0 or t.thread#=to_number(v.value))) i,
 (select value  from sys.v$parameter where name ='user_dump_dest' )  d;
 
阅读(2126) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~