• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Oracle 10046事件详解

mysql 搞代码 4年前 (2022-01-09) 17次浏览 已收录 0个评论

Oracle的10046事件,可以跟踪应用程序所执行的SQL语句,并且得到其解析次数.执行次数,CPU使用时间等信息。这对我们分析、定位数据

Oracle的10046事件,可以跟踪应用程序所执行的SQL语句,并且得到其解析次数.执行次数,CPU使用时间等信息。这对我们分析、定位数据库性能问题是非常有用的。

10046event是oracle用于系统性能分析时的一个最重要的事件。当激活这个事件后,将通知oracle kernel追踪会话的相关即时信息,并写入到相应trace文件中。这些有用的信息主要包括sql是如何进行解析,绑定变量的使用情况,会话中发生的等待事件等

本文来源gaodai$ma#com搞$$代**码网$10046event 可分成不同的级别(level),分别追踪记录不同程度的有用信息。对于这些不同的级别,应当注意的是向下兼容的,即高一级的trace信息包含低于此级的所有信息。

10046event的追踪级别大致有:

level 1:跟踪sql语句,包括解析、执行、提取、提交和回滚等。

level 4:包括变量的详细信息

level 8:包括等待事件

level 12:包括绑定变量与等待事件

其中,,level 1相当于打开了sql_trace

前提条件:
(先确保要event的会话环境符合条件)

1、必须确保timed_statistics为TRUE,这个参数可以在会话级上进行修改。

2、为了确保trace输出能够完整进行,还要调整此会话对trace文件大小的限制,一般将此限制取消,即将max_dump_file_size设置为UNLIMITED,或者设置为一个很大的阙值。

在满足了上述条件后,就可以启用10046event对会话进行后台跟踪了。

1、首先获得spid、sid、serial#,machine为连接oracle的机器名
select b.spid,a.sid,a.serial#,a.machine from v$session a,v$process b where a.paddr =b.addr and a.sid = ‘159’

继续往下看,就可以知道为什么找到SPID了;

2、10046事件启动
SQL>execute sys.dbms_system.set_ev(15,196,10046,1,”);
PL/SQL procedure successfully completed.

参数说明:
15:SID
196:SERIAL#

注意这里必须以sysdba登录。

或者会话级别的跟踪:

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

会话已更改。

3、在应用程序中执行对数据库的操作
比如性能较差的一些查询、插入、删除操作等。

4、10046事件的关闭
SQL>execute sys.dbms_system.set_ev(15,196,10046,0,”);

PL/SQL procedure successfully completed.

或者对应上面的,在会话级别关闭

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

会话已更改。

5、获得产生的跟踪文件所在的目录
SQL> select value from v$parameter where name = ‘user_dump_dest’;

转到该目录下可以看到生成了一个zftang_ora_596.trc文件,此处的596即SPID的值。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Oracle 10046事件详解
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址