ORACLE实时SQL监控视图_oracle视图是实时的吗-程序员宅基地

技术标签: oracle  数据库  sql  

 引言

       实时的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_id SQL语句的唯一标识符。
sql_exec_start SQL语句执行的开始时间。
sql_exec_id SQL语句执行的ID。
elapsed_time SQL语句的总执行时间。
cpu_time SQL语句消耗的CPU时间。
io_interconnect_bytes SQL语句执行期间的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的健康状态。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/pigoss02/article/details/131190869

智能推荐

使用nginx解决浏览器跨域问题_nginx不停的xhr-程序员宅基地

文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr

在 Oracle 中配置 extproc 以访问 ST_Geometry-程序员宅基地

文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc

Linux C++ gbk转为utf-8_linux c++ gbk->utf8-程序员宅基地

文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8

IMP-00009: 导出文件异常结束-程序员宅基地

文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束

python程序员需要深入掌握的技能_Python用数据说明程序员需要掌握的技能-程序员宅基地

文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求

Spring @Service生成bean名称的规则(当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致)_@service beanname-程序员宅基地

文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname

随便推点

二叉树的各种创建方法_二叉树的建立-程序员宅基地

文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include<stdio.h>#include<string.h>#include<stdlib.h>#include<malloc.h>#include<iostream>#include<stack>#include<queue>using namespace std;typed_二叉树的建立

解决asp.net导出excel时中文文件名乱码_asp.net utf8 导出中文字符乱码-程序员宅基地

文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码

笔记-编译原理-实验一-词法分析器设计_对pl/0作以下修改扩充。增加单词-程序员宅基地

文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词

android adb shell 权限,android adb shell权限被拒绝-程序员宅基地

文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限

投影仪-相机标定_相机-投影仪标定-程序员宅基地

文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定

Wayland架构、渲染、硬件支持-程序员宅基地

文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland

推荐文章

热门文章

相关标签