实时的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语句的性能特征,从而进行性能分析和优化。
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等)结合使用,以获取更全面的性能信息
例:强制监控一条查询语句
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的健康状态。