Oracle进程里的sql跟踪信息的收集

以下的文章主要讲述的是收集Oracle进程里的sql跟踪信息的实际操作方案,在相关的诊断数据库的系统性能的实际操作过程中,我们一般情况下都会运用到跟踪效率十分低下的sql的相关语句,现在就如何跟踪sql语句来做一个简单的总结。

权做抛砖引玉之用。如果我们可以修改应用系统的源代码,则可以直接在程序中加入如下的语句:

1)

  1. alter session set timed_statistics=true; 

适用于Oracle 7.3以后的版本

2)

  1. alter session set max_dump_file_size=unlimited ; 

适用于Oracle 7.3以后的版本

3)

  1. alter session set tracefile_identifier='POX20031031a'; 

适用于Oracle 8.1.7以后的版本

4)

  1. alter session set events '10046 trace name context forever, level 8'; 

/*在这里编写应用程序的代码

5)

  1. alter session set events '10046 trace name context off'; 

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

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

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

语句4)和语句5)的作用分别是打开和关闭跟sql跟踪,你可以在这两个语句之间写入应用程序的代码,这些代码的执行情况都将被跟踪。需要注意的是语句4)的level关键字,它用来指定跟踪级别,一共有0,1,2,4,8,12六个级别可以设置,0相当于关闭跟踪;

1是输出一般的跟踪信息,不包括绑定变量和等待信息;2和1相同;4是在级别1的基础上增加绑定变量信息;8是在级别1的基础上增加等待信息;级别12是输出包含级别1,4,8的所有信息。

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

1)

  1. sys.dbms_system.set_bool_param_in_session(:sid, :serial,'timed_statistics', true); 

2)

  1. sys.dbms_system.set_int_param_in_session( :sid, :serial,'max_dump_file_size', 2147483647); 

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

3.1)

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

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

4.1)

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

 

打开和关闭跟踪的第二种方法:

3.2)

  1. sys.dbms_system.set_ev(:sid, :serial, 10046, 8, ''); 

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

3.2)

  1. sys.dbms_system.set_ev(:sid, :serial, 10046, 0, ''); 

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

到现在为止,我们已经生成了所需要的跟踪文件,然后我们需要找到该文件来进行分析。跟踪文件的存放位置只有两种可能,Oracle参数USER_DUMP_DEST 或者BACKGROUND_DUMP_DEST指定的目录;

文件名称根据不同的平台会有所不同,但是在文件名中都会包含会话所对应的操作系统Oracle进程(线程)号,也就是V$PROCESS的SPID列(V$PROCESS.SPID) ,该信息可以通过 v$process.addr和v$session.paddr做表连接查询得到。例如:

  1. select spid from v$process p,v$session s where p.addr=
  2. s.paddr and s.sid=:sid and s.serial#=:serial. 

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

【编辑推荐】

  1. Oracle多表关联中的update语句实际应用
  2. Oracle数据库中两个易被忽视的进程
  3. Oracle rownum用法的归纳
  4. Oracle存储过程定时执行2种方法
  5. Oracle 10g中的hints调整机制详解

 

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/229670.html<

(0)
管理的头像管理
上一篇2025-04-18 21:18
下一篇 2025-04-18 21:19

相关推荐

  • 骨干网络体系结构能干什么?骨干网络体系结构的作用

    骨干网络体系结构是现代信息社会的“超级高速公路网”,它通过分层设计、冗余备份和智能调度,确保海量数据在全球范围内高速、稳定、安全地传输,是支撑云计算、物联网及人工智能应用的底层基石,想象一下,如果你把互联网比作一个巨大的城市交通系统,那么骨干网络就是连接各个城市的主干道和立交桥,没有它,你的每一次微信发送、每一……

    2026-06-18
    0
  • 高io数据库可以干什么用?高io数据库适合什么场景

    高IO数据库的核心价值在于通过极高的读写吞吐量,解决海量数据场景下的性能瓶颈,是支撑高并发交易、实时分析及大规模内容分发的关键基础设施,在数字化转型的深水区,数据不再仅仅是静态的记录,而是流动的资产,传统的机械硬盘或普通SSD早已无法满足现代应用对速度的极致追求,高IO(Input/Output)数据库,就是那……

    2026-06-18
    0
  • 高io服务器性能如何?高io服务器适合什么场景

    高IO服务器并非单纯指代某种硬件,而是指在随机读写、高并发连接及小文件处理场景下,具备极致IOPS(每秒输入输出操作次数)和低延迟特性的计算资源,它是支撑现代高并发应用稳定运行的核心基石,在2026年的数字化浪潮中,业务负载早已从简单的静态页面展示演变为复杂的实时数据处理,许多开发者在排查系统瓶颈时,往往忽略了……

    2026-06-18
    0
  • 隔离网络空间哪里便宜?国内隔离网络空间价格

    隔离网络空间并没有统一的“便宜”标准,其成本高度取决于物理隔离等级、带宽需求及安全合规要求,通常物理网闸方案初期投入较高但长期运维成本低,而逻辑隔离方案虽初期便宜但存在潜在安全风险,建议根据业务敏感度选择混合隔离架构以平衡成本与安全,在数字化时代,企业构建独立网络环境的需求日益增长,但“隔离网络空间哪里便宜”这……

    2026-06-18
    0
  • 骨干网络体系结构设备为何故障?常见原因有哪些

    骨干网络体系结构设备故障的核心原因通常归结为硬件老化、配置错误、物理链路中断及外部攻击四大类,其中电源模块失效与光模块性能衰减是占比最高的隐性故障源,骨干网作为数字经济的“大动脉”,其稳定性直接关乎国计民生,当核心路由器或交换机出现丢包、震荡甚至宕机时,运维人员往往面临巨大的压力,很多人第一反应是检查软件配置……

    2026-06-18
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注