0

0

通过案例学调优之--10046事件

php中文网

php中文网

发布时间:2016-06-07 16:47:56

|

1264人浏览过

|

来源于php中文网

原创

通过案例学调优之--10046事件10046事件概述Oracle的10046事件,可以跟踪应用程序所执行的SQL语句,并且得到其解析次数.执行次数,CPU使用时间等信息。这对我们分

(先确保要event的会话环境符合条件)

1、必须确保timed_statisticsTRUE,这个参数可以在会话级上进行修改。

关于参数timed_statistics的一段解释
      Without timed statistics, Oracle records the reason for each wait before it begins to wait, and when the wait is over, it records whether it timed out. But with timed statistics enabled, Oracle checks the time just before and after each wait, and also records the time waited. The time waited is recorded in hundredths of a second— that is, centiseconds.
true
      The statistics are collected and stored in trace files or displayed in the V$SESSTATS and V$SYSSTATS dynamic performance views.

false

     The value of all time-related statistics is set to zero. This setting lets Oracle avoid the overhead of requesting the time from the operating system.

      Starting with release 11.1.0.7.0, the value of the TIMED_STATISTICS parameter cannot be set to false if the value of STATISTICS_LEVEL is set to TYPICAL or ALL.

SQL Trace相关的参数

在打开10046时间的SQL Trace之前,要先设置好下面几个参数。

timed_statistics

这个参数决定了是否收集与时间相关的统计信息,如果这个参数为FALSE的话,那么SQL Trace的结果基本没有多大的用处,默认情况下这个参数设置为TRUE

max_dump_file_size

剪映
剪映

一款全能易用的桌面端剪辑软件

下载

dump文件的大小,也就是决定是否限制SQL Trace文件的大小,在一个很忙的系统上面做SQL Trace的话可能会生成很多的信息,因此最好在会话级别将这个参数设置成unlimited

tracefile_identifier

Trace文件设置识别字符串,这是个非常有用的参数,设置一个易读的字串能更快的找到Trace文件。

要在当前会话修改上述参数很简单,只要使用下面的命令即可:

ALTER SESSION SET timed_statistics=true ALTER SESSION SET max_dump_file_size=unlimited ALTER SESSION SET tracefile_identifier='my_trace_session

当然,这些参数可以在系统级别修改的,也可以加载init文件中或是spfile中,让系统启动时自动做全局设置。

要是在系统运行时动态的修改别的会话的这些参数就需要借助DBMS_SYSTEM这个包了,设置方法如下

SYS.DBMS_SYSTEM.SET_BOOL_PARAM_IN_SESSION(   :sid, :serial,   'timed_statistics', true )   SYS.DBMS_SYSTEM.SET_INT_PARAM_IN_SESSION(   :sid, :serial,   'max_dump_file_size', 2147483647 )

案例:

13:55:30 SYS@ prod >select username,sid,serial# from v$session where username is not null; USERNAME                              SID    SERIAL# ------------------------------ ---------- ---------- SYS                                     1          5 SCOTT                                  40        587 SYS                                    48        569 14:31:33 SYS@ prod >desc dbms_system PROCEDURE ADD_PARAMETER_VALUE  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  PARNAME                        VARCHAR2                IN  VALUE                          VARCHAR2                IN  SCOPE                          VARCHAR2                IN     DEFAULT  SID                            VARCHAR2                IN     DEFAULT  POSITION                       BINARY_INTEGER          IN     DEFAULT PROCEDURE DIST_TXN_SYNC  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  INST_NUM                       NUMBER                  IN PROCEDURE GET_ENV  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  VAR                            VARCHAR2                IN  VAL                            VARCHAR2                OUT PROCEDURE KCFRMS PROCEDURE KSDDDT PROCEDURE KSDFLS PROCEDURE KSDIND  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  LVL                            BINARY_INTEGER          IN PROCEDURE KSDWRT  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  DEST                           BINARY_INTEGER          IN  TST                            VARCHAR2                IN PROCEDURE READ_EV  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  IEV                            BINARY_INTEGER          IN  OEV                            BINARY_INTEGER          OUT PROCEDURE REMOVE_PARAMETER_VALUE  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  PARNAME                        VARCHAR2                IN  VALUE                          VARCHAR2                IN  SCOPE                          VARCHAR2                IN     DEFAULT  SID                            VARCHAR2                IN     DEFAULT PROCEDURE REMOVE_PARAMETER_VALUE  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  PARNAME                        VARCHAR2                IN  POSITION                       BINARY_INTEGER          IN  SCOPE                          VARCHAR2                IN     DEFAULT  SID                            VARCHAR2                IN     DEFAULT PROCEDURE SET_BOOL_PARAM_IN_SESSION  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  SID                            NUMBER                  IN  SERIAL#                        NUMBER                  IN  PARNAM                         VARCHAR2                IN  BVAL                           BOOLEAN                 IN PROCEDURE SET_EV  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  SI                             BINARY_INTEGER          IN  SE                             BINARY_INTEGER          IN  EV                             BINARY_INTEGER          IN  LE                             BINARY_INTEGER          IN  NM                             VARCHAR2                IN PROCEDURE SET_INT_PARAM_IN_SESSION  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  SID                            NUMBER                  IN  SERIAL#                        NUMBER                  IN  PARNAM                         VARCHAR2                IN  INTVAL                         BINARY_INTEGER          IN PROCEDURE SET_SQL_TRACE_IN_SESSION  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  SID                            NUMBER                  IN  SERIAL#                        NUMBER                  IN  SQL_TRACE                      BOOLEAN                 IN PROCEDURE WAIT_FOR_EVENT  Argument Name                  Type                    In/Out Default?  ------------------------------ ----------------------- ------ --------  EVENT                          VARCHAR2                IN  EXTENDED_ID                    BINARY_INTEGER          IN  TIMEOUT                        BINARY_INTEGER          IN  14:28:02 SYS@ prod >exec dbms_system.set_bool_param_in_session(40,587,'time_statistics',true); PL/SQL procedure successfully completed. 14:33:59 SYS@ prod >exec dbms_system.set_int_param_in_session(40,587,'max_dump_file_size',2147364847); PL/SQL procedure successfully completed.

10046 Trace启动方法

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

12

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

4

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

18

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

19

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

3

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.6万人学习

Java 教程
Java 教程

共578课时 | 53.8万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号