10046event 漫步:
如果你对 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 操作,并且应当及时关闭。
?
?
当利用事件 trace 完当前或某个 session 后,接下来我们的工作就是找到 oracle 生成的 trace 了。 Oracle 的初始化文件中 user_dump_dest 参数的设置将决定 trace 文件的生成位置。
?
从 trace 文件中查找和发现有用的信息,然后寻找必要的性能调整点并进行相应的调整:
大部分情况下,通过 10046 事件 trace 到文件里的信息包含了此会话中存在的性能问题,可以根据 trace 到的等待事件、 SQL 语句执行情况以及绑定变量的使用情况来进行分析和查找。
?
oracle 提供了一个工具 tkprof 来对 trace 文件进行格式的翻译,以便 trace 文件中记录的信息能够被我们容易掌握和获取。
?
?
小知识:
检查当前会话的 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;
6 ???????? /
the session sql_trace level is: 12
?
PL/SQL 过程已成功完成。