Maison base de données tutoriel 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启动方法

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment ajouter et remplacer les disques durs dans Oracle Rac Comment ajouter et remplacer les disques durs dans Oracle Rac Apr 11, 2025 pm 05:39 PM

Oracle RAC Hard Disk New and Remplacement Operations: Ajouter un disque dur: ajouter de nouveaux disques, créer des groupes de disques ASM, ajouter aux clusters, déplacer des fichiers de données. Remplacez le disque dur: identifiez le disque dur échoué, fermez le groupe de disque, remplacez le disque dur, rouvrez le groupe de disque, réparez le disque échoué et déplacez les fichiers de données.

Comment gérer le code brouillé d'Oracle Comment gérer le code brouillé d'Oracle Apr 11, 2025 pm 07:00 PM

Les problèmes brouillés d'Oracle sont généralement causés par des paramètres de caractéristiques incorrects. Les solutions incluent: la vérification du serveur, de la base de données et des jeux de caractères clients. Configurez le serveur, la base de données et les jeux de caractères clients selon les besoins. Utilisez la fonction Converti ou la fonction DBMS_LOB.Convert_lob pour fixer les données brouillées. Spécifiez toujours le jeu de caractères et définissez correctement les paramètres NLS.

Comment remettre à nouveau Oracle Comment remettre à nouveau Oracle Apr 11, 2025 pm 07:33 PM

Oracle fournit plusieurs méthodes de requête de déduplication: le mot-clé distinct renvoie une valeur unique pour chaque colonne. Le groupe par clause regroupe les résultats et renvoie une valeur non réactive pour chaque groupe. Le mot-clé unique est utilisé pour créer un index ne contenant que des lignes uniques, et l'interrogation de l'index sera automatiquement déducteur. La fonction ROW_NUMBER () attribue des nombres uniques et filtre les résultats qui contiennent uniquement la ligne 1. La fonction min () ou max () renvoie les valeurs non réactives d'une colonne numérique. L'opérateur intersecte renvoie les valeurs communes des deux ensembles de résultats (pas de doublons).

Comment vérifier la taille de l'espace de table d'Oracle Comment vérifier la taille de l'espace de table d'Oracle Apr 11, 2025 pm 08:15 PM

Pour interroger la taille de l'espace de table Oracle, suivez les étapes suivantes: Déterminez le nom de l'espace de table en exécutant la requête: sélectionnez Tablespace_name dans dba_tablespaces; Requête la taille de l'espace de table en exécutant la requête: sélectionnez SUM (Bytes) comme total_size, sum (bytes_free) comme disponible_space, sum (bytes) - sum (bytes_free) comme used_space à partir de dba_data_files où tablespace_

Comment se connecter à un serveur cloud Comment se connecter à un serveur cloud Apr 11, 2025 pm 06:51 PM

Les étapes pour se connecter à un serveur Cloud via un client Oracle sont les suivantes: Créez une clé SSH et copiez la clé publique sur le serveur Cloud. Configurez le client Oracle et ajoutez les informations de connexion du serveur Cloud au fichier tnsnames.ora. Créez une nouvelle connexion de base de données dans le client Oracle, entrez le nom d'utilisateur, le mot de passe et DSN. Cliquez sur OK et vérifiez que la connexion est réussie.

Résumé de la connaissance de base de la base de données Oracle Résumé de la connaissance de base de la base de données Oracle Apr 11, 2025 pm 06:33 PM

Oracle Database est un système de gestion de base de données relationnel fiable, évolutif et riche en fonctionnalités (RDBM). Son architecture suit le modèle client-serveur, y compris les composants côté serveur (Oracle Net), les instances, les zones de mémoire partagées (SGAS), les processus d'arrière-plan et les fichiers de base de données qui stockent les données. Les concepts de base incluent des tables, des lignes, des colonnes, des clés primaires, des clés étrangères, des index et des curseurs. La base de données est connue pour ses avantages tels que la haute disponibilité, le support des mégadonnées, les fonctionnalités riches, la forte sécurité et la facilité d'utilisation.

Comment modifier le jeu de caractères Oracle Comment modifier le jeu de caractères Oracle Apr 11, 2025 pm 06:57 PM

Pour modifier le jeu de caractères Oracle, vous devez: sauvegarder la base de données; Modifiez les paramètres du jeu de caractères dans le fichier init.ora; redémarrer la base de données; modifier les tables et colonnes existantes pour utiliser le nouveau jeu de caractères; Recharger les données; Modifiez le lien de la base de données (facultatif).

Comment utiliser les procédures stockées pour Oracle Comment utiliser les procédures stockées pour Oracle Apr 11, 2025 pm 07:03 PM

Une procédure stockée est un ensemble d'instructions SQL qui peuvent être stockées dans une base de données et peuvent être appelées à plusieurs reprises comme une unité distincte. Ils peuvent accepter les paramètres (in, out, inout) et fournir les avantages de la réutilisation du code, de la sécurité, des performances et de la modularité. Exemple: Créez une procédure stockée Calculer_Sum pour calculer la somme de deux nombres et les stocker dans le paramètre OUT.

See all articles