ORACLE实时SQL监控视图

news/2024/7/4 8:45:30

 引言

       实时的SQL监控(Real Time SQL Monitoring)是Oracle 11g的一个新特性,它是一项强大的工具,用于监视和分析正在执行的SQL语句的性能和执行计划。该功能允许我们实时地跟踪SQL查询的执行过程,以及了解其资源消耗、等待事件和执行计划等关键指标。

        在当今数据密集型应用环境下,实时SQL监控对于确保Oracle数据库的高效运行至关重要。Oracle数据库提供了多种强大的工具和视图,使我们能够深入了解SQL语句的执行情况、性能指标以及资源消耗情况。

 

        在Oracle 11g中,当SQL并行执行时,会立即被实时监控到,或者当SQL单进程运行时,若消耗超过5秒的CPU或I/O时间,则它也会被监控到。另外,若使用/*+ monitor */提示的SQL语句,则也会被强制监控到。若使用/*+ no_monitor */提示的SQL语句则不会被监控到。监控数据被记录在V$SQL_MONITOR视图中,当然也可以通过Oracle 11g新增的包DBMS_MONITOR来主动对SQL执行监控部署。

       V$SQL_MONITOR收集的信息每秒刷新一次,接近实时。当SQL执行完毕,信息并不会立即从V$SQL_MONITOR中删除,至少会保留1分钟。V$SQL_PLAN_MONITOR视图中的执行计划信息也是每秒更新一次,当SQL执行完毕,它们同样至少被保留1分钟。

视图主要字段说明

SQL_ID表示SQL语句的唯一标识符。通过该字段可以唯一标识和区分不同的SQL语句。
SQL_EXEC_START表示SQL语句的执行开始时间。该字段用于标识SQL语句执行的起始时间点
SQL_EXEC_ID表示SQL语句执行的ID。对于同一SQL语句的多次执行,该字段的值会不同,用于区分不同的执行实例。
SQL_PLAN_HASH_VALUE表示SQL语句执行计划的哈希值。执行计划是描述SQL查询优化和执行方式的关键信息,通过哈希值可以唯一标识不同的执行计划。
SQL_TEXT表示SQL语句的文本内容。该字段包含了完整的SQL查询语句。
ELAPSED_TIME

表示SQL语句的总执行时间。该字段用于衡量SQL查询的总体执行效率。

CPU_TIME表示SQL语句消耗的CPU时间。该字段用于衡量SQL查询在CPU资源上的消耗。
IO_INTERCONNECT_BYTES表示SQL语句执行期间的I/O互连字节数。该字段用于衡量SQL查询涉及的数据传输量。

        除了上述列外,V$SQL_MONITOR视图还提供了其他与SQL查询执行相关的列,例如等待事件、锁定信息、并行度等。这些信息可以帮助我们深入了解SQL语句的性能特征,从而进行性能分析和优化。

查询SQL语句消耗的资源信息

        

SELECT s.sql_id,
       s.sql_exec_start,
       s.sql_exec_id,
       s.elapsed_time,
       s.cpu_time,
       s.io_interconnect_bytes,
       s.sql_text
FROM v$sql_monitor s;

        上述查询语句将返回V$SQL_MONITOR视图中的以下列信息:

sql_idSQL语句的唯一标识符。
sql_exec_startSQL语句执行的开始时间。
sql_exec_idSQL语句执行的ID。
elapsed_timeSQL语句的总执行时间。
cpu_timeSQL语句消耗的CPU时间。
io_interconnect_bytesSQL语句执行期间的I/O互连字节数
sql_text表示SQL语句的文本内容。该字段包含了完整的SQL查询语句。

        用户可以通过查询V$SQL_MONITOR视图获得实时的SQL监控数据,并将其用于性能分析和调优;通常,可以通过JOIN操作将V$SQL_MONITOR视图与其他相关性能视图(如V$SQL、V$SQL_PLAN等)结合使用,以获取更全面的性能信息

获取SQL监控报告

        例:强制监控一条查询语句

select /*+ monitor */ count(*) from SYS.ACCESS$;

        查询V$SQL_MONTOR视图并获取需要生成报告的SQL_ID;除了可以生成TEXT格式,还可以生成HTML,ACTIVE

SELECT s.sql_id, s.sql_exec_start, s.sql_exec_id, s.elapsed_time, s.cpu_time, s.io_interconnect_bytes, s.sql_text FROM v$sql_monitor s;

        生成指定SQL_ID的SQL监控TEXT报告

SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR('4f9fbrbgh3c67') FROM DUAL ;

SQL Monitoring Report

SQL Text
------------------------------
select /*+ monitor */ count(*) from sys.ACCESS$

Global Information
------------------------------
 Status              :  DONE (ALL ROWS)     
 Instance ID         :  1                   
 Session             :  SYS (9:62224)       
 SQL ID              :  4f9fbrbgh3c67       
 SQL Execution ID    :  16777217            
 Execution Started   :  06/13/2023 16:32:58 
 First Refresh Time  :  06/13/2023 16:32:58 
 Last Refresh Time   :  06/13/2023 16:32:59 
 Duration            :  1s                  
 Module/Action       :  navicat.exe/-       
 Service             :  orcl                
 Program             :  navicat.exe         
 Fetch Calls         :  1                   

Global Stats
================================================================
| Elapsed |   Cpu   |    IO    | Fetch | Buffer | Read | Read  |
| Time(s) | Time(s) | Waits(s) | Calls |  Gets  | Reqs | Bytes |
================================================================
|    0.26 |    0.02 |     0.24 |     1 |    456 |   41 |   3MB |
================================================================

SQL Plan Monitoring Details (Plan Hash Value=2244184632)
=================================================================================================================================================
| Id |        Operation        |   Name    |  Rows   | Cost |   Time    | Start  | Execs |   Rows   | Read | Read  | Activity | Activity Detail |
|    |                         |           | (Estim) |      | Active(s) | Active |       | (Actual) | Reqs | Bytes |   (%)    |   (# samples)   |
=================================================================================================================================================
|  0 | SELECT STATEMENT        |           |         |      |         1 |     +1 |     1 |        1 |      |       |          |                 |
|  1 |   SORT AGGREGATE        |           |       1 |      |         1 |     +1 |     1 |        1 |      |       |          |                 |
|  2 |    INDEX FAST FULL SCAN | I_ACCESS1 |   30515 |   29 |         1 |     +1 |     1 |     105K |   41 |   3MB |          |                 |
=================================================================================================================================================

总结

        V$SQL_MONITOR是Oracle数据库中用于实时监控正在执行的SQL语句的动态性能视图。它提供了关于SQL语句执行的详细信息,包括执行计划、资源消耗和等待事件等。通过查询V$SQL_MONITOR视图,可以获取实时的SQL监控数据,帮助用户进行性能分析和调优

        PIGOSS BSM将不断完善对Oracle数据库的监控,结合专业DBA的经验,并且与一线运维人员是使用场景紧密结合。不仅能监控到oracle的关键性能指标信息,而且通过丰富的图表将数据库的各项指标运行状态直观地展现给用户,帮助用户全面了解oracle的健康状态。


http://www.niftyadmin.cn/n/4464361.html

相关文章

matlab学习笔记(二)---三维图形的绘制

1、三维螺线例子: t0:pi/50:10*pi;xsin(t);ycos(t);zt;hplot3(x,y,z);set(h,LineWidth,4*get(h,LineWidth));grid图像如下: 2、用plot3函数重叠绘制多条曲线 xlinspace(0,3*pi);z1sin(x);z2sin(2*x);z3sin(3*x);y1zeros(size(x));y3zeros(size(x));y2y3…

matlab学习笔记(三)---图像的代数运算

1、绝对值差函数imabstiff Iimread(cameraman.tif);Juint8(filter2(fspecial(gaussian),I));Kimabsdiff(I,J);imshow(I);imshow(K,[]);</span>原图和处理后的图如下&#xff1a; 2、图像的叠加函数imadd Iimread(rice.png);Jimread(cameraman.tif);Kimadd(I,J,uint16);im…

platform_device与驱动的联系

首先你需要为SOC的各个功能部分定义他的一些资源.例如可用于访问的寄存器地址.中断号,DMA什么的。然后将这些资源(resource) 作为 platform 的dev .通过platform_add_devices函数将你定义的paltform_device变量注册到系统的dev里面.。或者你可以象我这样将你需要的驱动添加:sta…

find查找文件的时候排除某个或几个文件或目录 find . * -path src -o -prune -print | xargs -i mv {} desc

比如要在/usr/sam目录下查找不在dir1子目录之内的所有文件 find /usr/sam -path "/usr/sam/dir1" -prune -o -printfind [-path ..] [expression] 在路径列表的后面的是表达式-path "/usr/sam" -prune -o -print 是 -path "/usr/sam" -a -prune …

matlab学习笔记(四)--- 图像的几何操作

1、改变图像的大小imresize imresize的调用方法&#xff1a; Yimresize(X,M,Method); 其中X表示原图像&#xff0c;M表示方法倍数&#xff0c;Method表示使用何种差值方法&#xff0c;默认最近邻插值法。 Iimread(circuit.tif);Jimresize(I,1.25);imshow(I);figure,imshow(J…

mini2440开发之完全摆脱windows环境(未验证)

我们进行mini2440的linux开发&#xff0c;如果能只在linux下工作&#xff0c;工作效率会提高不少&#xff0c;也少了很多麻烦&#xff0c;省得来回切换&#xff0c;另外&#xff0c;linux下的工具可能比windows下还好用些。 我们为什么离不开windows呢&#xff1f;因为我们要用…

matlab学习笔记(五)---空域变换增强-直接灰度调整

1、像素选择 &#xff08;1&#xff09;函数pixval(matlab7.8中此函数已过时)&#xff0c;改用impixelinfo&#xff0c;用来测试像素的值。 imshow canoe.tif;impixelinfo效果图如下&#xff1a;&#xff08;2&#xff09;函数impixel&#xff0c;用来得到像素的值。 语法格式…

带USB下载功能的uboot,支持mini2440(未验证)

带USB下载功能的uboot&#xff0c;支持mini2440(百问网原创) 文章发表于&#xff1a;2008-11-17 15:34 能做出这个uboot的人也就是论坛的坛主 thisway.diy&#xff0c;《嵌入式linux应用开发板完全手册》的作者韦东山&#xff0c;人称南山大哥。感谢他的开源代码&#xff0c;我…