ORACLE实时SQL监控视图

这篇具有很好参考价值的文章主要介绍了ORACLE实时SQL监控视图。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

 引言

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

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

ORACLE实时SQL监控视图,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的健康状态。

ORACLE实时SQL监控视图,oracle,sql,数据库文章来源地址https://www.toymoban.com/news/detail-562031.html

到了这里,关于ORACLE实时SQL监控视图的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 用SQL语句操作Oracle数据库——数据更新

    数据库中的数据更新操作有3种:1)向表中添加若干行数据(增);2)删除表中的若干行数据(删);3)修改表中的数据(改)。对于这3种操作,SQL语言中有3种相应的语句与之对应。接下来让我们逐一详细地了解一下。 本文我们依然使用以下三个表来进行数据更新操作:

    2024年01月19日
    浏览(67)
  • Oracle数据库SQL Plus基础命令

    1.使用SQL*Plus登录Oracle数据库 开始 -- 所有程序 -- Oracle -- 应用程序开发 -- SQL Plus cmd窗口下输入:sqlplus 用户名/口令@主机字符串 2.使用CMD命令登录Oracle数据库 开始 -- 所有程序 -- 附件 -- 命令提示符 使用命令行登陆的连接命令格式为:sqlplus/@net_service_name username为用户名;passw

    2024年02月06日
    浏览(54)
  • oracle如何定期备份数据库sql文件

    Oracle数据库可以使用以下方法定期备份数据库的SQL文件: 使用Oracle的备份和恢复工具RMAN(Recovery Manager)进行备份。RMAN提供了全面而高效的数据库备份和恢复功能。您可以使用RMAN备份数据库的SQL文件,并将其存储在指定的位置。可以使用RMAN备份的命令来备份数据库,例如:

    2024年01月25日
    浏览(82)
  • Sql server和Oracle默认数据库

            SQL Server 和 Oracle 都有自带的一些默认数据库,保存了不同的系统信息和配置数据。         SQL Server 上的默认数据库:          master :SQL Server 引擎的系统级目录,存储了 所有系统层级的信息和元数据 ,例如登录账号信息。         tempdb:存储各种系

    2024年02月09日
    浏览(62)
  • 主流数据库(SQL Server、Mysql、Oracle)通过sql实现多行数据合为一行

    1、方法一:使用 STUFF 和 FOR XML PATH 进行多行合并成一行 (1)FOR XML PATH用法 FOR XML 是 SQL Server 提供的一种功能,允许您将查询结果转换为 XML 格式。 PATH 模式则是其中一种灵活的方式来构造自定义的XML结构。 1、基本字符串连接 : 当您想从单列中提取所有行的数据并连接成一

    2024年04月10日
    浏览(63)
  • DB(一):数据库概述、SQL概述、Oracle数据类型

    包括Oracle、DB2、SQL Server、MySQL数据库概述;数据定义语言DDL、数据操作语言DML、事务控制语言TCL、数据查询语言DQL、数据控制语言DCL语言介绍;NUMBER 、CHAR、VARCHAR2、DATE数据库类型;CHAR和VARCHAR2的存储编码、CHAR和VARCHAR2的最大长度、LONG和CLOB类型。 1、DB和DBMS (1)、数据库(

    2024年02月09日
    浏览(82)
  • ORACLE数据库 —— PL/SQL知识点2

    ORACLE数据库  PL/SQL语句基础知识点  适合有SQL基础的人群。  禁止转载! 内置函数 字符串函数     lower(列名|字符串)函数用于返回字符串的小写形式。         eg.SELECT ename,sal FROM emp WHERE ename=lower(\\\'ename\\\');     upper(列名|字符串)函数用于返回字符串的大写形式。       

    2024年02月08日
    浏览(53)
  • Oracle/PL/SQL数据库基础操作(持续更新)

            PL/SQL不是一个独立的编程语言;它是Oracle编程环境中的工具。 SQL* Plus是一个互动的工具,它可以在命令提示符下键入SQL和PL/SQL语句。这些命令发送到数据库进行处理。语句处理之后将结果发回,并在屏幕上显示出来。 分类 命令 DDL create:创建;drop:删除;alter:

    2024年02月09日
    浏览(63)
  • 【数据库】日常使用PL/SQL 登录ORACLE 数据库查询数据

    一、PL/SQL 登录方式 username: ##访问数据库的账号 password: ##访问数据库的密码 Databse: ##数据库IP地址/实例名 数据库集群心跳地址/实例名 Connect as : ##Normal,如果使用sysdba账户登录选择SYSDBA 二、PL/SQL使用SQL语句查询 点击上方导航栏,New,选择SQL Window,即可再次输入要查询的

    2024年02月19日
    浏览(70)
  • 用PL/SQL Developer连接远程Oracle数据库

    oracle数据库安装教程参考 注意: 第六步中的Oracle基目录中的用户名为中文的话,需要去掉中文部分。然后管理口令一定保存好。 2.打开oracle安装目录(默认在C盘,我的在D盘),找到tnsnames.ora文件 这是oracle客户端所需要的一个文件,通过该文件可以配置数据库的连接地址,

    2024年02月13日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包