当前位置:Gxlcms > 数据库问题 > Oracle SQL调优系列之SQL Monitor Report

Oracle SQL调优系列之SQL Monitor Report

时间:2021-07-01 10:21:17 帮助过:6人阅读

@目录

  • 1、SQL Monitor简介
  • 2、捕捉sql的前提
  • 3、SQL Monitor 参数设置
  • 4、SQL Monitor Report
    • 4.1、SQL_ID获取
    • 4.2、Text文本格式
    • 4.3、Html格式
    • 4.4、ACTIVE格式
    • 4.5 SQL Monitoring list
  • 5、SQL Monitor Report查询
    • 5.1、查看所有的sql monitor report
    • 5.2、查看某个sql的sql monitor report
    • 5.3、查看某个sql的整体性能
    • 5.4、查看整个系统的性能

1、SQL Monitor简介

sql monitor是oracle官方提供的自动监控符合特定条件的SQL,用于收集执行时的细节信息的监控工具,常用于sql调优和系统性能监控

2、捕捉sql的前提

sql monitor 捕捉sql的前提:

  • 并行执行的sql语句
  • 单次执行消耗的CPU或IO超过5秒
  • statistics_level级别必须是TYPICAL 或者ALL
  • 使用/* +MONITOR*/ HINT的SQL语句

3、SQL Monitor 参数设置

  • STATISTICS_LEVEL必须设置为:‘TYPICAL‘(缺省)或者 ‘ALL‘
  • CONTROL_MANAGEMENT_PACK_ACCESS设置为:‘DIAGNOSTIC+TUNING‘

查看statistics_level参数

  1. <code class="language-sql">show parameter statistics_level;
  2. </code>

技术图片
建议还是改变Session就可以

  1. <code class="language-sql">alter session set statistics_level=ALL;
  2. </code>

查看参数CONTROL_MANAGEMENT_PACK_ACCESS

  1. <code class="language-sql">show parameter CONTROL_MANAGEMENT_PACK_ACCESS;
  2. </code>

技术图片

4、SQL Monitor Report

本博客采用DBMS_SQLTUNE包DBMS_SQLTUNE.report_sql_monitor的方式获取,报告格式有:‘TEXT‘,‘HTML‘,‘XML‘ ,‘ACTIVE‘,其中‘ACTIVE‘只在11g R2以后才支持

4.1、SQL_ID获取

sql monitor使用,必须在sql中使用/* +MONITOR*/ Hint,然后数据会存在v$sql_monitor表里

随意找条sql,注意要加/*+ moniotr*/

  1. <code class="language-sql">
  2. select /*+ moniotr*/ a.user_code, a.full_name, a.user_pwd, c.unit_code, c.unit_name
  3. from base_user a
  4. left join (select ur.user_code, ur.unit_code
  5. from t_user_role ur
  6. where ur.user_role < 10) b
  7. on a.user_code = b.user_code
  8. left join t_unit_info c
  9. on b.unit_code = c.unit_code
  10. where c.unit_code in
  11. (select uinfo.unit_code
  12. from t_unit_info uinfo
  13. start with uinfo.unit_code = ‘15803‘
  14. connect by prior uinfo.unit_code = uinfo.para_unit_code);
  15. </code>

提供sql查询,获取sql_id

  1. <code class="language-sql">select sql_id,sql_text from v$sql_monitor where sql_text like ‘%t_unit_info%
  2. </code>

4.2、Text文本格式

将上面查询到的sql_id改下,然后执行如下SQL:

  1. <code class="language-sql">SET LONG 1000000
  2. SET LONGCHUNKSIZE 1000000
  3. SET LINESIZE 1000
  4. SET PAGESIZE 0
  5. SET TRIM ON
  6. SET TRIMSPOOL ON
  7. SET ECHO OFF
  8. SET FEEDBACK OFF
  9. spool report_sql_monitor_text.txt
  10. SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(
  11. SQL_ID => ‘g9rtj389t0g66‘,
  12. TYPE => ‘TEXT‘,
  13. REPORT_LEVEL => ‘ALL‘) AS REPORT
  14. FROM dual;
  15. spool off
  16. </code>

获取到text格式的sql monitor
技术图片

4.3、Html格式

  1. <code class="language-sql">SET LONG 1000000
  2. SET LONGCHUNKSIZE 1000000
  3. SET LINESIZE 1000
  4. SET PAGESIZE 0
  5. SET TRIM ON
  6. SET TRIMSPOOL ON
  7. SET ECHO OFF
  8. SET FEEDBACK OFF
  9. spool report_sql_monitor_html.html
  10. SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(
  11. SQL_ID => ‘g9rtj389t0g66‘,
  12. TYPE => ‘HTML‘,
  13. REPORT_LEVEL => ‘ALL‘) AS REPORT
  14. FROM dual;
  15. spool off
  16. </code>

获取到对应报告,可以看到执行计划、Buffer Gets 等等信息
技术图片

4.4、ACTIVE格式

ACTIVE格式需要下载相应的flash组件、脚本,详细见SQL Monitor Report 使用详解

  1. <code class="language-sql">SET LONG 1000000
  2. SET LONGCHUNKSIZE 1000000
  3. SET LINESIZE 1000
  4. SET PAGESIZE 0
  5. SET TRIM ON
  6. SET TRIMSPOOL ON
  7. SET ECHO OFF
  8. SET FEEDBACK OFF
  9. spool report_sql_monitor_active.html
  10. SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(
  11. SQL_ID => ‘2rjh5d5k2yujz‘,
  12. TYPE => ‘ACTIVE‘,
  13. REPORT_LEVEL => ‘ALL‘,
  14. BASE_PATH => ‘http://ip/script‘) AS REPORT
  15. FROM dual;
  16. spool off
  17. </code>

4.5 SQL Monitoring list

如果要获取所有sql monitor,就可以使用如下SQL:

  1. <code class="language-sql">SET LONG 1000000
  2. SET LONGCHUNKSIZE 1000000
  3. SET LINESIZE 1000
  4. SET PAGESIZE 0
  5. SET TRIM ON
  6. SET TRIMSPOOL ON
  7. SET ECHO OFF
  8. SET FEEDBACK OFF
  9. SPOOL report_sql_monitor_list.html
  10. SELECT dbms_sqltune.report_sql_monitor_list(
  11. type => ‘HTML‘,
  12. report_level => ‘ALL‘) AS report
  13. FROM dual;
  14. SPOOL OFF
  15. </code>

技术图片

5、SQL Monitor Report查询

提供sql monitor常用的查询脚本

5.1、查看所有的sql monitor report

  • 查看所有的sql monitor report
  1. <code class="language-sql"> select dbms_sqltune.report_sql_monitor from dual;
  2. </code>

5.2、查看某个sql的sql monitor report

  • 查看某个sql的sql monitor report
  1. <code class="language-sql"> SELECT DBMS_SQLTUNE.report_sql_monitor(sql_id => ‘2rjh5d5k2yujz‘, type => ‘TEXT‘) from dual;
  2. </code>

5.3、查看某个sql的整体性能

  • 查看某个sql的整体性能
  1. <code class="language-sql"> SELECT DBMS_SQLTUNE.report_sql_monitor_list(sql_id=>‘2rjh5d5k2yujz‘,type =>‘TEXT‘,report_level => ‘ALL‘) AS report FROM dual;
  2. </code>

5.4、查看整个系统的性能

  • 查看整个系统的性能
  1. <code class="language-sql"> SELECT DBMS_SQLTUNE.report_sql_monitor_list(type =>‘TEXT‘,report_level => ‘ALL‘) AS report FROM dual;
  2. </code>

相关SQL脚本下载:sql download

Oracle SQL调优系列之SQL Monitor Report

标签:dba   lan   color   自动   lis   sql_id   ffffff   lines   系统   

人气教程排行