10046 event

     假如您对oracle性能调优很感兴趣或比较专长,那么您对oracle的10046事件一定不会陌生。10046event是oracle用于系统性能分析时的一个最重要的事件。当激活这个事件后,将通知oracle kernel追踪会话的相关实时信息,并写入到相应trace文档中。这些有用的信息主要包括sql是如何进行解析,绑定变量的使用情况,会话中发生的等待事件等
  
  10046event 可分成不同的级别(level),分别追踪记录不同程度的有用信息。对于这些不同的级别,应当注意的是向下兼容的,即高一级的trace信息包含低于此级的任何信息。
  
  10046event的追踪级别大致有:
  level 1:跟踪sql语句,包括解析、执行、提取、提交和回滚等。
  
  level 4:包括变量的周详信息
  
  level 8:包括等待事件
  
  level 12:包括绑定变量和等待事件
  
  其中,level 1相当于打开了sql_trace
  
  10046event的启用和关闭:
  前提条件:(先确保要event的会话环境符合条件)
  
  1.必须确保timed_statistics为TRUE,这个参数能够在会话级上进行修改。
  
  2.为了确保trace输出能够完整进行,还要调整此会话对trace文档大小的限制,一般将此限制取消,即将max_dump_file_size配置为UNLIMITED,或配置为一个很大的?值。 中国.网管联盟
  
  在满足了上述条件后,就能够启用10046event对会话进行后台跟踪了。
  
  这里更有几种方式来启用10046event:
  
  一种是在当前会话启用event,能够利用alter session + 事件名称 + level,
  
  如:sql>alter session set event ‘10046 trace name context forever, level 12’;
  
  另外一种是启用别的会话进行event跟踪,能够利用oracle提供的dbms_system来完成。
  
  如:sql>exec dbms_system.set_ev(sid,serial#,10046,12,’’);
  
  注意:
  sql>exec dbms_system.set_sql_trace_in_session(sid,serial#,true);
  
  相当于打开了sql_trace。
  
  event的关闭:
  能够在通过下面的语句来关闭当前会话的event:
  
  sql>alter session set event ‘10046 trace name context off’;
  
  也能够利用dbms_system包来关闭某个会话的event:
  
  sql>execute dbms_system.set_ev(sid,serial#,0,’’);
  
  这里应当值得一提的是,TRACE将消耗相当的系统资源,因此我们在使用TRACE的时候应当慎重。对于正式的系统,应当只在必要的时候进行TRACE操作,并且应当及时关闭。 bitsCN.Com
  
  当利用事件trace完当前或某个session后,接下来我们的工作就是找到oracle生成的trace了。Oracle的初始化文档中user_dump_dest参数的配置将决定trace文档的生成位置。
  
  从trace文档中查找和发现有用的信息,然后寻找必要的性能调整点并进行相应的调整:
  
  大部分情况下,通过10046事件trace到文档里的信息包含了此会话中存在的性能问题,能够根据trace到的等待事件、SQL语句执行情况连同绑定变量的使用情况来进行分析和查找。
  
  oracle提供了一个工具tkprof来对trace文档进行格式的翻译,以便trace文档中记录的信息能够被我们容易掌控和获取。

例子:

SQL>  alter session set events '10046 trace name context forever, level 12' ; 

Session altered.

SQL> alter table sfism4.aaaa move tablespace log_data ; 

Table altered.

SQL> alter session set events '10046 trace name context off' ; 

Session altered.


  
  小知识:
  检查当前会话的sql_trace状态或级别:
  
  SQL>set serveroutput on
  
  2 declare i_event number;
  
  3 begin
  
   3 sys.dbms_system.read_ev(10046,i_event);
  
   4 dbms_output.put_line(‘the session sql_trace level is: ‘||i_event);
  
   5 end;
  
  the session sql_trace level is: 12
  
  PL/SQL 过程已成功完成。

请使用浏览器的分享功能分享到微信等