产品:
- Oracle Database – 企业版 – 版本 6.0.0.0 及更高版本
- 本文档内容适用于任何平台
需要的权限:
- 数据库管理员 – 需要访问数据库来收集数据
系统影响:
- 无 – 以下的收集指令不会对系统有任何影响
提供一步步的指导来对 SQL 性能问题收集诊断日志。
诊断文件列表
1) 使用 SQL Health Check 检查语句 [ ] 2) 使用 SQLT 的 XTRXEC 模式收集诊断信息 [ ] 如果不能收集 SQLT 2) 手工收集诊断日志 [ ] a) 语句的全文 – 完整的有问题的语句的 SQL 文本 [ ] b) 收集有问题的执行计划 [ ] c) 收集好的执行计划(如果有的话) [ ] d) 收集有问题时的 10046 trace [ ] e) 收集没问题时的 10046 trace(如果有的话) [ ] 整理并上传诊断日志 3) 整理并上传诊断日志 [ ]
性能问题的诊断信息
1) 使用 SQL Health Check 检查语句
下载并运行 SQLHC 工具
# sqlplus / as sysdba SQL> START sqlhc.sql [T|D|N] [SQL_ID]
关于如何使用 SQLHC 收集 SQL 性能问题的信息,请参照下面的文章:
检查 SQLHC 的推荐
检查 SQL Health Check 工具的推荐,如果文件 sqlhc_IDENTIFIER_1_health_check.html 中的内容不能帮我们解决问题,那么上传 SQLHC 输出到 SR。
2) 使用 SQLT 的 XTRXEC 模式收集诊断信息
除了 SQLHC 的输出,收集这个语句的 SQLT 输出。你需要先下载并安装 SQLT。以 XTRXEC 模式收集 SQLT,这样同时收集到运行时以及优化器的信息。
XTRXEC 模式收集足够的信息(包括运行这个语句),如下:
使用 SQL*PLUS 以执行有问题语句的应用账号连接,并执行 sqlt/run/sqltxtrxec.sql 脚本,并提供 SQL_ID 或者 HASH_VALUE。
# cd sqlt/run # sqlplus apps SQL> START sqltxtrxec.sql [SQL_ID]|[HASH_VALUE]
如果这个语句有正常的时候(比如在其他的系统上,或者不同版本,或者不同的用户下,或者在不同的参数下),那么也同时收集正常时候的 SQLT 以做对比。
如果如何使用 SQLT 收集 SQL 性能问题的诊断日志,请参考下面的文章:
如果不能收集 SQLT
2) 手工收集诊断日志
SQLT 可以一次运行就收集大部分诊断性能问题所需要的信息,但是如果因为一些原因您不能使用 SQLT,那么您需要手工收集下面的信息。
2a) 语句的全文 – 完整的有问题的语句的 SQL 文本
收集问题语句的文本全文
2b) 收集有问题的执行计划
在 10.2 及更高版本上,如果语句已经执行了,可以从 library cache 中拿到执行计划(和之前的版本只能收集标准的执行计划相比)。要收集最近一次执行的执行计划,执行下面的命令:
SQL> set pagesize 2000
SQL> spool problem_explain.txt
SQL> select * from table(dbms_xplan.display_cursor(null,null, ‘ALL’));
SQL> spool off
关于更多方法,请参考:
2c) 收集好的执行计划(如果可能的话)
如果有好的执行计划,那么像上面一样收集好的执行计划,spool 到一个”good_explain.txt”的文件中。
2d) 收集有问题时候的 10046 trace
在 session level 收集这个语句的 10046 trace:
alter session set timed_statistics = true;
alter session set statistics_level=all;
alter session set max_dump_file_size = unlimited;
oradebug setmypid
oradebug tracefile_name
alter session set events ‘10046 trace name context forever,level 12’;
— 在这里执行需要被 trace 语句或者操作 —
select * from dual;
exit;
trace 文件会显示在”oradebug tracefile_name” 命令的输出中。
注意:如果并未使用绑定变量,那么使用 level 8,因为 level 12 会产生更大的日志。
如果语句无法在合理的时间内完成,那么就 trace 一个合理的时间后,就取消它。
如果 session 不能退出,那么可以执行下面的语句关闭 trace:
关于更多收集 10046 trace 的方式,请参考文档:
2e) 收集没问题时候的 10046 trace(如果可能的话)
如果语句有正常的时候,那么也对好的时候收集 10046 trace,使用’good_10046′ 作为 trace 的标识:
下一步
3) 整理并上传诊断日志
如果在检查和实施了 SQL Health Check 的推荐后,仍然无法解决问题,那么可以从下面的文档中找到更多分析 SQL 性能问题的方式:
如果无法解决问题,整理并上传诊断日志给技术支持,并且提供一个清晰的问题描述。在大部分情况下这些信息已经足够,但还是有些情况会要收集更多的信息。
SQL Health Check 输出文件:sqlhc_IDENTIFIER_1_health_check.html |
语句的 XTRACT 模式的 SQLT 输出 |
如果不能收集 SQLT,上传
|
Comment