首页 数据库 mysql教程 通过案例学调优之--10046事件

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

Jun 07, 2016 pm 04:47 PM
oracle 调优

通过案例学调优之--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启动方法

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

oracle数据库日志会保存多久 oracle数据库日志会保存多久 May 10, 2024 am 03:27 AM

Oracle 数据库日志的保留期限取决于日志类型和配置,包括:重做日志:由 "LOG_ARCHIVE_DEST" 参数配置的最大大小决定。归档重做日志:由 "DB_RECOVERY_FILE_DEST_SIZE" 参数配置的最大大小决定。在线重做日志:不归档,在数据库重启时丢失,保留期限与实例运行时间一致。审计日志:由 "AUDIT_TRAIL" 参数配置,默认保留 30 天。

oracle需要多少内存 oracle需要多少内存 May 10, 2024 am 04:12 AM

Oracle 所需内存量取决于数据库大小、活动水平和所需性能水平:用于存储数据缓冲区、索引缓冲区、执行 SQL 语句和管理数据字典缓存。具体数量受数据库大小、活动水平和所需性能水平影响。最佳实践包括设置适当的 SGA 大小、调整 SGA 组件大小、使用 AMM 和监控内存使用情况。

oracle数据库服务器硬件配置要求 oracle数据库服务器硬件配置要求 May 10, 2024 am 04:00 AM

Oracle 数据库服务器硬件配置要求:处理器:多核,主频至少 2.5 GHz,大型数据库建议 32 核以上。内存:小型数据库至少 8GB,中等规模 16-64GB,大型数据库或高负载工作负载高达 512GB 或更多。存储:SSD 或 NVMe 磁盘,RAID 阵列提高冗余和性能。网络:高速网络(10GbE 或更高),专用网卡,低延迟网络。其他:稳定电源、冗余组件、兼容操作系统和软件、散热和冷却系统。

用oracle数据库需要多大内存 用oracle数据库需要多大内存 May 10, 2024 am 03:42 AM

Oracle 数据库所需内存量取决于数据库大小、工作负载类型和并发用户数量。通常建议:小型数据库:16-32 GB,中型数据库:32-64 GB,大型数据库:64 GB 或更多。其他需考虑因素包括数据库版本、内存优化选项、虚拟化和最佳实践(监视内存使用情况、调整分配)。

oracle定时任务每天都执行一次创建步骤 oracle定时任务每天都执行一次创建步骤 May 10, 2024 am 03:03 AM

要在 Oracle 中创建每天执行一次的定时任务,需要执行以下三个步骤:创建一个作业。为作业添加一个子作业,并设置其计划表达式为“INTERVAL 1 DAY”。启用作业。

oracle怎么启动监听程序 oracle怎么启动监听程序 May 10, 2024 am 03:12 AM

Oracle 监听程序用于管理客户端连接请求。启动步骤包括:登录到 Oracle 实例。找到监听程序配置。使用 lsnrctl start 命令启动监听程序。使用 lsnrctl status 命令验证启动。

oracle数据库启动有哪几个阶段 oracle数据库启动有哪几个阶段 May 10, 2024 am 03:15 AM

Oracle 数据库启动分为7个阶段:1. 初始化;2. 实例恢复;3. 归档日志恢复;4. 崩溃恢复;5. 对象开放;6. 服务器准备;7. 服务器启动。该过程涉及加载库文件、配置参数、恢复数据库实例、应用归档日志、更新数据文件和对象,最终启动数据库服务以接受查询。

oracle数据库删除表字段语句 oracle数据库删除表字段语句 May 10, 2024 am 02:24 AM

Oracle数据库中,使用ALTER TABLE语句删除表字段:语法:ALTER TABLE table_name DROP COLUMN column_name;删除字段前,确保无约束引用该字段。字段包含数据时,需先清空数据。删除字段不可逆,操作前需谨慎考虑。

See all articles