网站首页站长博客下载中心域名交易站长论坛域名主机免费电邮免费域名中文排行排名查询站长书库书籍教程下载
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
学院首页 网络编程 网页设计 图形图象 数 据 库 服 务 器 网络媒体 网络安全 个人专栏 站长CLUB 业界新闻 信息公告
 当前位置:首页 >> 数 据 库 >> Oracle >> 正文
公告通知
返回上级列表
资料搜索
相关文章
 管理作业自动化
备份SQL Server     
还原及回复数据库   
使用者与安全性管理
精通数据库系列之入门-技巧篇5
精通数据库系列之入门-技巧篇3
精通数据库系列之入门-技巧篇2
精通数据库系列之入门-技巧篇1
 Access数据库的存储上限
如何使用Oracle的BFILE 
10046event 漫步
[ 来源:CSDN | 作者:无从考证 | 时间:2005-11-18 16:23:02 | 浏览:人次 ]
收藏到新浪ViVi 收藏到365KEY 收藏到我摘  字号选择〖    〗/ 双击滚屏 单击停止  
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 过程已成功完成。

[发送给好友]  [打印本页]  [关闭窗口]  [返回顶部]   转载请注明来源:http://edu.chinaz.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
栏目编辑: 设计风 责任编辑: 简若宁
原始作者: 无从考证 录入时间: 2005-11-18 16:23:02
信息来源: CSDN 投稿信箱: Edu#chinaz.com
设为首页 - 加入收藏 - 关于我们 - 广告服务 - 版权申明 - 友情链接 - 联系方式 - 总编信箱 - 会员投稿