SQL Monitor Report总结学习

1. SQL Monitor简介

在Oracle Database 11g中,系统自动监控符合以下条件的SQL,并收集执行时的细节信息:

1)采用并行方式执行

2)单次执行消耗的CPU或IO超过5秒

3)通过使用/* +MONITOR*/  HINT的语句

系统收集的SQL信息会存储在V$SQL_MONITOR、V$SQL_PLAN_MONITOR视图中

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

 

spool report_sql_monitor_active.html

SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(

  SQL_ID       => 'g59kf70w1dpku',

  TYPE         => 'ACTIVE',

  REPORT_LEVEL => 'ALL') AS report

FROM dual;

spool off

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

SPOOL REPORT_SQL_DETAIL_HTML.HTML

SELECT dbms_sqltune.REPORT_SQL_DETAIL(SQL_ID   => 'g59kf70w1dpku',

                                 TYPE         => 'active',

                                 report_level => 'ALL') AS report

FROM dual;

SPOOL OFF

2. SQL Monitor 参数设置(默认就是开启的)

STATISTICS_LEVEL设置为:'TYPICAL'(缺省)或者 'ALL'

CONTROL_MANAGEMENT_PACK_ACCESS设置为:'DIAGNOSTIC+TUNING'

3. SQL Monitor report获取方法

SQL Monitoring可以采用以下3种方式展现:

1)EM:Performance  ——>右下角的SQL Monitoring ——>Monitored SQL Executions

2)SQL Developer:Tools ——>Monitor SQL

3)DBMS_SQLTUNE包 ——> DBMS_SQLTUNE.report_sql_monitor

其报告格式有:'TEXT','HTML','XML' ,'ACTIVE',其中'ACTIVE'只在11g R2以后才支持,使用HTML和Flash的方式显示动态的报告,需要从oracle官网读取相关联的Javascript和Flash。

备注:

如果不能连到Internet又想看ACTIVE Report可以下载相关的库文件到本地的HTTP服务器上,然后用BASE_PATH来制定库文件的位置。

在本地HTTP服务器上创建目录,然后下载下面的文件:

mkdir -p /var/www/html/sqlmon

cd /var/www/html/sqlmon

wget --mirror --no-host-directories --cut-dirs=1 http://download.oracle.com/otn_software/emviewers/scripts/flashver.js

wget --mirror --no-host-directories --cut-dirs=1 http://download.oracle.com/otn_software/emviewers/scripts/loadswf.js

wget --mirror --no-host-directories --cut-dirs=1 http://download.oracle.com/otn_software/emviewers/scripts/document.js

wget --mirror --no-host-directories --cut-dirs=1 http://download.oracle.com/otn_software/emviewers/sqlmonitor/11/sqlmonitor.swf

在调用函数时加上参数,比如:base_path => 'http://ipaddr/sqlmon'

 

 

4.SQL Monitor report生成实例

语法:

DBMS_SQLTUNE.REPORT_SQL_MONITOR()

 

FUNCTION REPORT_SQL_MONITOR RETURNS CLOB

 Argument Name                  Type                    In/Out Default?

 ------------------------------ ----------------------- ------ --------

 SQL_ID                         VARCHAR2                IN     DEFAULT

 SESSION_ID                     NUMBER                  IN     DEFAULT

 SESSION_SERIAL                 NUMBER                  IN     DEFAULT

 SQL_EXEC_START                 DATE                    IN     DEFAULT

 SQL_EXEC_ID                    NUMBER                  IN     DEFAULT

 INST_ID                        NUMBER                  IN     DEFAULT

 START_TIME_FILTER              DATE                    IN     DEFAULT

 END_TIME_FILTER                DATE                    IN     DEFAULT

 INSTANCE_ID_FILTER             NUMBER                  IN     DEFAULT

 PARALLEL_FILTER                VARCHAR2                IN     DEFAULT

 PLAN_LINE_FILTER               NUMBER                  IN     DEFAULT

 EVENT_DETAIL                   VARCHAR2                IN     DEFAULT

 BUCKET_MAX_COUNT               NUMBER                  IN     DEFAULT

 BUCKET_INTERVAL                NUMBER                  IN     DEFAULT

 BASE_PATH                      VARCHAR2                IN     DEFAULT

 LAST_REFRESH_TIME              DATE                    IN     DEFAULT

 REPORT_LEVEL                   VARCHAR2                IN     DEFAULT

 TYPE                           VARCHAR2                IN     DEFAULT

 SQL_PLAN_HASH_VALUE            NUMBER                  IN     DEFAULT

4.1 Text文本格式

1)  Sqlplus 参数设置查看

show parameter statistics_level;

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

statistics_level                     string      TYPICAL

show parameter CONTROL_MANAGEMENT_PACK_ACCESS;

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

control_management_pack_access       string      DIAGNOSTIC+TUNING

2)  执行模拟SQL

[oracle@node4 sqlmonitor]$ sqlplus -S /nolog

conn /as sysdba;

select /* +moniotr*/* from scott.dept where deptno<=30;

 

             DEPTNO DNAME          LOC

---------- -------------- -------------

        10 ACCOUNTING     NEW YORK

        20 RESEARCH       DALLAS

        30 SALES          CHICAGO

3)  从v$sql_monitor获取模拟SQL信息

col sql_text for a60;

set line 200;

set pagesize 20000;

 

select sql_id,sql_text from v$sql_monitor where sql_text like '%scott.dept%';

 

SQL_ID        SQL_TEXT

------------- ------------------------------------------------------------

74qqqwntwzxb1 select /*+ Monitor*/ * from scott.dept where deptno=10

4)  生成text类型报告

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

spool report_sql_monitor_text.txt

SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(

  SQL_ID       => '74qqqwntwzxb1',

  TYPE         => 'TEXT',

  REPORT_LEVEL => 'ALL') AS REPORT

FROM dual;

spool off

 

5)  展示报告内容

4.2 HTML格式

1)生成HTML类型报告(生成到登录sqlplus的目录)

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

 

spool report_sql_monitor_html.html

SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(

  SQL_ID       => '74qqqwntwzxb1',

  TYPE         => 'HTML',

  REPORT_LEVEL => 'ALL') AS REPORT

FROM dual;

spool off

 

2)html类型报告展示

4.3 Active格式

如不能联网,需要下载相应的flash组件、脚本,详细见SQL Monitor report获取方法

1)active类型报告生成 (生成到登录sqlplus的目录)

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

 

spool report_sql_monitor_active.html

SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(

  SQL_ID       => '74qqqwntwzxb1',

  TYPE         => 'ACTIVE',

  REPORT_LEVEL => 'ALL') AS report

FROM dual;

spool off

 

2)active类型报告展示

 

可以通过启动http服务,将文件放置在发布目录下,通过http://ipaddr/sqlmon/report_sql_monitor_active.html形式查看(需下载相应的脚本和组件)

 

或者拿到windows本地查看

5.          SQL Monitor report其他方法使用

1)DBMS_SQLTUNE.REPORT_SQL_MONITOR_LIST

FUNCTION REPORT_SQL_MONITOR_LIST RETURNS CLOB

 Argument Name                  Type                    In/Out Default?

 ------------------------------ ----------------------- ------ --------

 SQL_ID                         VARCHAR2                IN     DEFAULT

 SESSION_ID                     NUMBER                  IN     DEFAULT

 SESSION_SERIAL                 NUMBER                  IN     DEFAULT

 INST_ID                        NUMBER                  IN     DEFAULT

 ACTIVE_SINCE_DATE              DATE                    IN     DEFAULT

 ACTIVE_SINCE_SEC               NUMBER                  IN     DEFAULT

 LAST_REFRESH_TIME              DATE                    IN     DEFAULT

 REPORT_LEVEL                   VARCHAR2                IN     DEFAULT

 AUTO_REFRESH                   NUMBER                  IN     DEFAULT

 BASE_PATH                      VARCHAR2                IN     DEFAULT

 TYPE                           VARCHAR2                IN     DEFAULT

需要Oracle 11g R2以上版本。此函数用于产生一个对监控SQL的汇总页,类似于EM中的“Monitored SQL Executions”。

常用参数:TYPE和REPORT_LEVEL,用法与REPORT_SQL_MONITOR类似。

例如:

conn /as sysdba;

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

SPOOL REPORT_SQL_MONITOR_LIST.HTML

SELECT dbms_sqltune.report_sql_monitor_list(

  type         => 'HTML',

  report_level => 'ALL') AS report

FROM dual;

SPOOL OFF

 

2)DBMS_SQLTUNE.REPORT_SQL_DETAIL

FUNCTION REPORT_SQL_DETAIL RETURNS CLOB

 Argument Name                  Type                    In/Out Default?

 ------------------------------ ----------------------- ------ --------

 SQL_ID                         VARCHAR2                IN     DEFAULT

 SQL_PLAN_HASH_VALUE            NUMBER                  IN     DEFAULT

 START_TIME                     DATE                    IN     DEFAULT

 DURATION                       NUMBER                  IN     DEFAULT

 INST_ID                        NUMBER                  IN     DEFAULT

 DBID                           NUMBER                  IN     DEFAULT

 EVENT_DETAIL                   VARCHAR2                IN     DEFAULT

 BUCKET_MAX_COUNT               NUMBER                  IN     DEFAULT

 BUCKET_INTERVAL                NUMBER                  IN     DEFAULT

 TOP_N                          NUMBER                  IN     DEFAULT

 REPORT_LEVEL                   VARCHAR2                IN     DEFAULT

 TYPE                           VARCHAR2                IN     DEFAULT

 DATA_SOURCE                    VARCHAR2                IN     DEFAULT

 END_TIME                       DATE                    IN     DEFAULT

 DURATION_STATS                 NUMBER                  IN     DEFAULT

需要Oracle 11g R2以上版本。此函数用于根据各种条件参数(包括:start_time, end_time, duration, inst_id, dbid, event_detail, bucket_max_count, bucket_interval, top_n, duration_stats),产生比使用REPORT_SQL_MONITOR更加详细的SQL报告。

例如:

conn /as sysdba;

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

SPOOL REPORT_SQL_DETAIL_HTML.HTML

SELECT dbms_sqltune.REPORT_SQL_DETAIL(SQL_ID   => '74qqqwntwzxb1',

                                 TYPE         => 'active',

                                 report_level => 'ALL') AS report

FROM dual;

SPOOL OFF

ERROR:

ORA-13971: Component "sql_detail" unknown

ORA-06512: at "SYS.DBMS_SYS_ERROR", line 95

ORA-06512: at "SYS.DBMS_REPORT", line 166

ORA-06512: at "SYS.DBMS_REPORT", line 612

ORA-06512: at "SYS.DBMS_REPORT", line 1079

ORA-06512: at "SYS.DBMS_REPORT", line 1135

ORA-06512: at "SYS.DBMS_SQLTUNE", line 20101

ORA-06512: at line 1

(上述错误在指定html格式,调整为active格式即可)

可以针对topSQL

conn /as sysdba;

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

SPOOL REPORT_SQL_DETAIL.HTML

SELECT dbms_sqltune.report_sql_detail(top_n        => 5,

                                 TYPE         => 'active',

                                 report_level => 'ALL') AS report

FROM dual;

SPOOL OFF

### 关于MonitorApplication的技术文档 #### 故障排查指南 对于`MonitorApplication`中的常见故障,有效的排查流程能够显著减少解决问题的时间并提高系统的稳定性。当遇到应用监控数据缺失或异常波动的情况时,应首先确认配置文件是否正确无误[^3]。 如果发现监控指标未能正常更新,则需检查网络连接状态以及服务端口开放情况。此外,还需验证应用程序的日志记录功能是否开启,并查看日志中是否有任何错误提示信息。针对数据库层面的问题,可以利用SQL Monitor Report来分析查询性能瓶颈所在之处;例如,在OceanBase环境中,可以通过观察DFO(Data Flow Operation)的操作细节找出潜在的数据流阻塞点[^2]。 #### 使用教程概览 为了更好地理解和操作`MonitorApplication`,以下是几个关键概念及其应用场景: - **仪表盘定制**:允许用户根据个人需求创建自定义视图,以便直观地展示重要的业务KPI和其他实时统计数据。 - **告警设置**:支持多种类型的阈值触发机制,一旦检测到超出预设范围的事件发生即可立即通知相关人员采取行动。 - **历史数据分析**:提供强大的检索工具帮助管理员回顾过去一段时间内的系统表现趋势,从而做出更加明智的战略决策。 在具体实施过程中,建议遵循官方提供的安装向导完成初始部署工作之后再逐步深入学习各项高级特性。同时也要注意定期备份重要参数设定以免意外丢失造成不便。 ```bash # 安装依赖库 pip install monitor-application-lib==1.0.0 # 启动服务 monitor-app start --config=/path/to/config.yaml ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值