网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > 数据库技术 > Oracle > PL/SQL > 如何收集sql跟踪信息  

如何收集sql跟踪信息

2005-12-29  作者:BitsCN整理  来源:中国网管联盟  点评 投稿 收藏

  在诊断数据库系统性能的过程中,总会涉及到跟踪效率低下的sql语句,现在就如何跟踪sql语句来做一个简单的总结。权做抛砖引玉之用。

网管u家bitscn.net

  如果我们可以修改应用系统的源代码,则可以直接在程序中加入如下的语句:

网管有家bitscn.net

  1)alter session set timed_statistics=true; /*适用于Oracle 7.3以后的版本*/

网管u家www.bitscn.net

  2)alter session set max_dump_file_size=unlimited ; /*适用于Oracle 7.3以后的版本*/

网管u家bitscn.net

  3)alter session set tracefile_identifier='POX20031031a'; /*适用于Oracle 8.1.7以后的版本*/

网管u家bitscn.net

  4)alter session set events '10046 trace name context forever, level 8';

网管u家bitscn.net

  /*在这里编写应用程序的代码*/ 网管下载dl.bitscn.com

  5)alter session set events '10046 trace name context off';

网管bitscn_com

  在上述语句中,语句1)是把该会话的时间统计打开,该参数默认为false.在Oracle 7.3之前的版本中,不能在会话级设置该参数,只能修改初始化文件然后重新启动数据库,这样将在实例级打开时间统计。 网管u家bitscn.net

  语句2)是把跟踪文件的大小设置成操作系统所允许的最大尺寸,这样可以防止跟踪文件在完成所需要的跟踪之前被填充满,此外需要注意的是确保存放跟踪文件的目录要有足够的空间,否则将会收到“文件系统已满”错误。

中国网管联盟bitsCN.com

  语句3)的作用是使生成的跟踪文件名称中包含'POX20031031a'字符串,这样可以使你很容易的找到所需的跟踪文件,该参数在Oracle 8.1.7之后可用。 网管网www.bitscn.com

  语句4)和语句5)的作用分别是打开和关闭跟sql跟踪,你可以在这两个语句之间写入应用程序的代码,这些代码的执行情况都将被跟踪。需要注意的是语句4)的level关键字,它用来指定跟踪级别,一共有0,1,2,4,8,12六个级别可以设置,0相当于关闭跟踪;1是输出一般的跟踪信息,不包括绑定变量和等待信息;2和1相同;4是在级别1的基础上增加绑定变量信息;8是在级别1的基础上增加等待信息;级别12是输出包含级别1,4,8的所有信息。 网管联盟bitsCN_com

  如果应用程序的代码无法修改或者是不想去修改,则可以在其他会话中打开对特定会话的跟踪,方法如下:

网管u家bitscn.net

  1)sys.dbms_system.set_bool_param_in_session(:sid, :serial,'timed_statistics', true); 网管u家bitscn.net

  2)sys.dbms_system.set_int_param_in_session( :sid, :serial,'max_dump_file_size', 2147483647); 网管有家www.bitscn.net

  打开和关闭跟踪的第一种方法(oracle推荐): 网管网www_bitscn_com

  3.1)sys.dbms_support.start_trace_in_session(:sid, :serial,waits=>true, binds=>false);

网管下载dl.bitscn.com

  /* 在此期间运行要跟踪的应用程序*/

网管联盟bitsCN_com

  4.1)sys.dbms_support.stop_trace_in_session(:sid, :serial);

中国网管联盟bitsCN.com

  打开和关闭跟踪的第二种方法: 网管u家www.bitscn.net

  3.2)sys.dbms_system.set_ev(:sid, :serial, 10046, 8, ''); 网管u家u.bitscn@com

  /*在此期间运行要跟踪的应用程序*/ 网管bitscn_com

  3.2)sys.dbms_system.set_ev(:sid, :serial, 10046, 0, ''); 网管联盟bitsCN_com

  以上语句中的:sid和:serial分别代表所要跟踪的会话的ID和序列号,这些信息可以从V$SESSION视图的SID和SERIAL#列获得。打开关闭跟踪中第一种方法的好处是你不用自己写10046这个事件号,这样可以减少错误,但是dbms_support程序包在你的数据库中可能会不存在,这样就只有用第二种方法了。 中国网管联盟bitsCN.com

  到现在为止,我们已经生成了所需要的跟踪文件,然后我们需要找到该文件来进行分析。跟踪文件的存放位置只有两种可能,Oracle参数USER_DUMP_DEST 或者BACKGROUND_DUMP_DEST指定的目录;文件名称根据不同的平台会有所不同,但是在文件名中都会包含会话所对应的操作系统进程(线程)号,也就是V$PROCESS的SPID列(V$PROCESS.SPID) ,该信息可以通过 v$process.addr和v$session.paddr做表连接查询得到。例如:select spid from v$process p,v$session s where p.addr=s.paddr and s.sid=:sid and s.serial#=:serial.

中国网管联盟bitsCN.com

  本文只对Oracle在使用专用服务器进程(Dedicated Server)模式做了总结,至于的共享服务器(Shared Server)模式和在应用级使用连接池的情况下,收集sql跟踪信息的方法会比较复杂,希望有相关经验的高手来总结。

中国网管论坛bbs.bitsCN.com

TAGs信息   跟踪   收集   如何   语句   打开   sid   serial    
 上一篇:sqlplus的oci prefetch特性   下一篇:查找bad sql的方法
相关文章列表
如何收集sql跟踪信息 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
1.PL/SQL - 嵌套游标 cursor-PLSQL
2.用一个实例讲解Oracle数据库的PL/SQL语句
3.PL/SQL----触发器-PLSQL
4.mysql存储过程写法—动态参数运用-PLSQL
5.PL/SQL Developer导出分区索引脚本-PLSQL
6.PL/SQL collection— table() 函数-PLSQL
7.SQL Server 2005 中的架构与用户-PLSQL
8.Oracle数据库维护常用SQL语句集合(2)-P
9.Oracle数据库维护常用SQL语句集合(3)-P
10.再议SQL Server临时表和表变量-PLSQL
最新推荐文章:
1.与数据库无关的处理放到数据库以外来实现
2.Oracle 10g第2版新特性之SQL和PL/SQL
3.通过PL/SQL访问Web Services
4.菜鸟学oracle - 用PL/SQL画直方图
5.重新编译PLSQL中无效对象或指定对象
6.Oracle高级技巧
7.深入了解Oracle 10g新的多重集运算符
8.在SQL中删除重复记录(多种方法)
9.Oracle:PL/SQL中怎样使用Array
10.数据库手册:速查Oracle函数列表
网管论坛交流:
·大家来开心一下吧---看了会很开心的东西-
·中国人不可不知道的知识
·@@小鹏◎◎小鹏同志与某位女明星亲密接触
·◎◎小鹏◎◎发现不明生物,居然正在交配
·[图文]^^^版主是什么?????
·泡论坛的女人是好女人
·做个“水性杨花”的女人
·献给mm俱乐部的所有mm
·深圳一集团企业电脑基础应用培训教程
·■■■■十一遊玩照■■■■■