<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Decode360's Blog

    業精于勤而荒于嬉 QQ:150355677 MSN:decode360@hotmail.com

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 ::  :: 管理 ::
      302 隨筆 :: 26 文章 :: 82 評論 :: 0 Trackbacks
    Tracing SQL in Oracle Database 10g
    By Kimberly Floss
    ?
    New tools help you better understand the performance of your applications.
    ?
    In a busy production environment with many active users, tracing a SQL session is time-consuming and complicated, because processing SQL statements in any multitier system that uses a connection pool can span multiple processes, or even different instances.
    ?
    With Oracle Database 10g, Oracle rationalizes SQL tracing through a new built-in package, DBMS_MONITOR, which encompasses the functionality of previously undocumented trace tools, such as the DBMS_SUPPORT package. Now you can easily trace any user's session from beginning to end—from client machine to middle tier to back end—and generate trace files based on specific client ID, module, or action.
    ?
    In addition, Oracle Database 10g includes a new utility, trcsess, that lets you selectively extract trace data from numerous trace files and save them into a single file, based on criteria such as session ID or module name. This utility is especially useful in a shared server configuration, since a dispatcher may route each user request to a different shared server process, resulting in multiple trace files for any given session. Rather than digging through numerous trace files, Oracle Database 10g's trcsess lets you obtain consolidated trace information pertaining to a single user session.
    ?
    Getting Started
    ?
    As with prior Oracle database releases, trace files are output to the directory specified by the user_dump_dest parameter of the server's initialization file (or spfile). The default location depends on the operating system; for example, for Microsoft Windows platforms using DBCA, the default is $ORACLE_BASE\instance_name\admin\udump, where instance_name is the name of the Oracle instance. You can dynamically change this parameter by using the alter system command:

    alter system set user_dump_dest="c:\kflosstrace";

    You can also add your own marker to the trace file names so you can more easily find the generated files. To do so, set the tracefile_identifier initialization parameter before starting a trace:

    alter session set
    tracefile_identifier ="kfloss_test";

    Trace files generated by this command have the string value you set appended to the filenames. Although neither of these alter commands is necessary, both make it easier to find the results of a tracing session.
    ?
    Now that we've set these parameters, let's look at the new tracing package and the Oracle Enterprise Manager interface. Let's set up a trace by module name and client name, using the new DBMS_MONITOR package.
    ?
    Setting Up Tracing with DBMS_MONITOR
    ?
    The DBMS_MONITOR package has routines for enabling and disabling statistics aggregation as well as for tracing by session ID, or tracing based upon a combination of service name, module name, and action name. (These three are associated hierarchically: you can't specify an action without specifying the module and the service name, but you can specify only the service name, or only the service name and module name.) The module and action names, if available, come from within the application code. For example, Oracle E-Business Suite applications provide module and action names in the code, so you can identify these by name in any of the Oracle Enterprise Manager pages. (PL/SQL developers can embed calls into their applications by using the DBMS_APPLICATION_INFO package to set module and action names.)
    ?
    Note that setting the module, action, and other paramters such as client_id no longer causes a round-trip to the database—these routines now piggyback on all calls from the application.
    ?
    The service name is determined by the connect string used to connect to a service. User sessions not associated with a specific service are handled by sys$users (sys$background is the default service for the background processes). Since we have a service and a module name, we can turn on tracing for this module as follows:

    SQL> exec dbms_monitor.serv_mod_act_trace_enable
    (service_name=>'testenv', module_name=>'product_update');
    ?
    PL/SQL procedure successfully completed.

    We can turn on tracing for the client:

    SQL> exec dbms_monitor.client_id_trace_enable
    (client_id=>'kimberly');
    ?
    PL/SQL procedure successfully completed.

    Note that all of these settings are persistent—all sessions associated with the service and module will be traced, not just the current sessions.
    ?
    To trace the SQL based on the session ID, look at the Oracle Enter-prise Manager Top Sessions page, or query the V$SESSION view as you likely currently do.

    SQL> select sid, serial#, username
    from v$session;
    ?????? SID???? SERIAL#?USERNAME
    ???? ------??? -------?------------
    ?????? 133?????? 4152? SYS
    ?????? 137?????? 2418? SYSMAN
    ?????? 139???????? 53? KIMBERLY
    ?????? 140??????? 561? DBSNMP
    ?????? 141????????? 4? DBSNMP
    . . .
    ?????? 168????????? 1
    ?????? 169????????? 1
    ?????? 170????????? 1
    28 rows selected.

    With the session ID (SID) and serial number, you can use DBMS_MONITOR to enable tracing for just this session:

    SQL> exec dbms_monitor.session_trace_enable(139);
    ?
    PL/SQL procedure successfully completed.

    The serial number defaults to the current serial number for the SID (unless otherwise specified), so if that's the session and serial number you want to trace, you need not look any further. Also, by default, WAITS are set to true and BINDS to false, so the syntax above is effectively the same as the following:
    ?

    SQL> exec dbms_monitor.session_trace_enable
    (session_id=>139, serial_num=>53, waits=>true, binds=>false);
    ?

    Note that WAITS and BINDS are the same parameters that you might have set in the past using DBMS_SUPPORT and the 10046 event.
    ?
    If you're working in a production environment, at this point you'd rerun the errant SQL or application, and the trace files would be created accordingly.
    ?
    Setting Up Tracing with Enterprise Manager
    ?
    Setting up tracing through Oracle Enterprise Manager starts on the Top Consumers page (available from the Performance page in the Additional Monitoring Links section, as shown in Figure 1). This page shows the system's current resource usage by service, module, client, and action.
    ?
    o54talking_f1.jpg
    Figure 1: Oracle Enterprise Manager Top Consumers page?
    ?

    You can click on the Top Services, Top Modules, Top Actions, Top Clients, or Top Sessions tabs to see the detail for each of these categories of top consumers, and then you can easily enable (or disable) SQL tracing from each of these pages. Simply select the item from the list on the page and then click on Enable SQL Trace to begin the trace (and click on Disable when you're finished).
    ?
    You can enable (or disable) statistics aggregation for any items listed on these pages as well. (DBMS_MONITOR also provides routines for enabling and disabling aggregation.)
    ?
    Analyzing Trace Results
    ?
    Whether you use DBMS_MONITOR or Oracle Enterprise Manager to set up tracing, you'll use the trcsess command line tool to consolidate trace files. Click on the View SQL Trace button in Oracle Enterprise Manager to display a page that shows the syntax you'll use to consolidate all trace files.
    ?
    Be sure to double-quote the strings, and add a ".trc" extension to the filename; otherwise, TKPROF won't accept it as a filename. Before executing the command, navigate to the directory specified in the user_dump_dest (or \udump, if you didn't change this parameter name).
    ?

    C:\...\udump> trcsess output="kfloss.trc" service="testenv"
    module="product update"
    action="batch insert"
    ?

    You can then run TKPROF against the consolidated trace file to generate a report.
    ?

    C:\...\udump> tkprof kfloss.trc
    output=kfloss_trace_report SORT=(EXEELA, PRSELA, FCHELA)
    ?

    If you don't disable tracing, every session that runs that service and module will be traced. Thus, when you're finished, be sure to disable tracing by using either Oracle Enterprise Manager or the DBMS_MONITOR package.
    ?

    --------------------------------------------------------------------------------
    Kimberly Floss (
    kimberly_floss@ioug.org ) is president of the International Oracle Users Group ( www.ioug.org ). She specializes in Oracle performance tuning and SQL tuning techniques and is also the author of Oracle SQL Tuning and CBO Internals (Rampant TechPress, 2004).
    ?
    ?
    ?
    ?
    ?
    ?
    ?
    ?
    DBMS_MONITOR包的定義說明
    -------------------------------------

    create or replace package sys.dbms_monitor is

    ? ------------

    ? --? OVERVIEW

    ? --

    ? --? This package provides database monitoring functionality, initially

    ? --? in the area of statistics aggregation and SQL tracing

    ?

    ? --? SECURITY

    ? --

    ? --? runs with SYS privileges.

    ?

    ? --? CONSTANTS to be used as OPTIONS for various procedures

    ? --? refer comments with procedure(s) for more detail

    ?

    ? all_modules??????????????????? CONSTANT VARCHAR2 ( 14 ) := '###ALL_MODULES' ;

    ? all_actions??????????????????? CONSTANT VARCHAR2 ( 14 ) := '###ALL_ACTIONS' ;

    ?

    ? -- Indicates that tracing/aggregation for a given module should be enabled

    ? -- for all actions

    ?

    ? ----------------------------

    ?

    ? ----------------------------

    ? --? PROCEDURES AND FUNCTIONS

    ? --

    ? PROCEDURE client_id_stat_enable(

    ??? client_id IN VARCHAR2 );

    ?

    ? --? Enables statistics aggregation for the given Client ID

    ? --? Input arguments:

    ? --?? client_id?????????? - Client Identifier for which the statistics

    ? --???????????????????????? colection is enabled

    ?

    ? PROCEDURE client_id_stat_disable(

    ??? client_id IN VARCHAR2 );

    ?

    ? --? Disables statistics aggregation for the given Client ID

    ? --? Input arguments:

    ? --?? client_id?????????? - Client Identifier for which the statistics

    ? --???????????????????????? colection is disabled

    ?

    ? PROCEDURE serv_mod_act_stat_enable(

    ??? service_name IN VARCHAR2 ,

    ??? module_name IN VARCHAR2 ,

    ??? action_name IN VARCHAR2 DEFAULT ALL_ACTIONS);

    ?

    ? --? Enables statistics aggregation for the given service/module/action

    ? --? Input arguments:

    ? --?? service_name??????? - Service Name for which the statistics

    ? --???????????????????????? colection is enabled

    ? --?? module_name???????? - Module Name for which the statistics

    ? --???????????????????????? colection is enabled

    ? --?? action_name???????? - Action Name for which the statistics

    ? --????????????? ???????????colection is enabled. The name is optional.

    ? --???????????????????????? if omitted, statistic aggregation is enabled

    ? --???????????????????????? for all actions in a given module

    ?

    ? PROCEDURE serv_mod_act_stat_disable(

    ??? service_name IN VARCHAR2 ,

    ??? module_name IN VARCHAR2 ,

    ??? action_name IN VARCHAR2 DEFAULT ALL_ACTIONS);

    ?

    ? --? Disables statistics aggregation for the given service/module/action

    ? --? Input arguments:

    ? --?? service_name??????? - Service Name for which the statistics

    ? --???????????????????????? colection is disabled

    ? --?? module_name???????? - Module Name for which the statistics

    ? --???????????????????????? colection is disabled

    ? --?? action_name???????? - Action Name for which the statistics

    ? --??????????????????? ?????colection is disabled. The name is optional.

    ? --???????????????????????? if omitted, statistic aggregation is disabled

    ? --???????????????????????? for all actions in a given module

    ?

    ? PROCEDURE client_id_trace_enable(

    ??? client_id IN VARCHAR2 ,

    ??? waits IN BOOLEAN DEFAULT TRUE ,

    ??? binds IN BOOLEAN DEFAULT FALSE );

    ?

    ? --? Enables SQL for the given Client ID

    ? --? Input arguments:

    ? --?? client_id?????????? - Client Identifier for which SQL trace

    ? --???????????????????????? is enabled

    ? --?? waits?? ????????????- If TRUE, wait information will be present in the

    ? --???????????????????????? the trace

    ? --?? binds?????????????? - If TRUE, bind information will be present in the

    ? --???????????????????????? the trace

    ?

    ? PROCEDURE client_id_trace_disable(

    ??? client_id IN VARCHAR2 );

    ?

    ? --? Disables SQL trace for the given Client ID

    ? --? Input arguments:

    ? --?? client_id?????????? - Client Identifier for which SQL trace

    ? --???????????????????????? is disabled

    ?

    ? PROCEDURE serv_mod_act_trace_enable(

    ??? service_name IN VARCHAR2 ,

    ??? module_name IN VARCHAR2 DEFAULT ALL_MODULES,

    ??? action_name IN VARCHAR2 DEFAULT ALL_ACTIONS,

    ??? waits IN BOOLEAN DEFAULT TRUE ,

    ??? binds IN BOOLEAN DEFAULT FALSE ,

    ??? instance_name IN VARCHAR2 DEFAULT NULL );

    ?

    ? --? Enables SQL trace for the given service/module/action

    ? --? Input arguments:

    ? --?? service_name??????? - Service Name for which SQL trace

    ? --???????????????????????? is enabled

    ? --?? module_name???????? - Module Name for which SQL trace

    ? --???????????????? ????????is enabled. The name is optional.

    ? --???????????????????????? if omitted, SQL trace is enabled

    ? --???????????????????????? for all modules and actions actions in a given

    ? --???????????????????????? service

    ? --?? action_name???????? - Action Name for which SQL trace

    ? --???????????????????????? is enabled. The name is optional.

    ? --???????????????????????? if omitted, SQL trace is enabled

    ? --???????????????????????? for all actions in a given module

    ? --?? waits?????????????? - If TRUE, wait information will be present in the

    ? --???????????????????????? the trace

    ? --?? binds?????????????? - If TRUE, bind information will be present in the

    ? --???????????????????????? the trace

    ? --?? instance_name?????? - if set, restricts tracing to the named instance

    ?

    ? PROCEDURE serv_mod_act_trace_disable(

    ??? service_name IN VARCHAR2 ,

    ??? module_name IN VARCHAR2 DEFAULT ALL_MODULES,

    ??? action_name IN VARCHAR2 DEFAULT ALL_ACTIONS,

    ??? instance_name IN VARCHAR2 DEFAULT NULL );

    ?

    ? --? Disables SQL trace for the given service/module/action

    ? --? Input arguments:

    ? --?? service_name??????? - Service Name for which SQL trace

    ? --???????????????????????? is disabled

    ? --?? module_name???????? - Module Name for which SQL trace

    ? --???????????????????????? is disabled. The name is optional.

    ? --???????????????????????? if omitted, SQL trace is disabled

    ? --???????????????????????? for all modules and actions actions in a given

    ? --?? action_name???????? - Action Name for which SQL trace

    ? --???????????????????????? is disabled. The name is optional.

    ? --???????????????????????? if omitted, SQL trace is disabled

    ? --???????????????????????? for all actions in a given module

    ? --???????????????????????? the trace

    ? --?? instance_name?????? - if set, restricts disabling to the named instance

    ?

    ? PROCEDURE session_trace_enable(

    ??? session_id IN BINARY_INTEGER DEFAULT NULL ,

    ??? serial_num IN BINARY_INTEGER DEFAULT NULL ,

    ??? waits IN BOOLEAN DEFAULT TRUE ,

    ??? binds IN BOOLEAN DEFAULT FALSE );

    ?

    ? --? Enables SQL trace for the given Session ID

    ? --? Input arguments:

    ? --?? session_id????????? - Session Identifier for which SQL trace

    ? --???????????????????????? is enabled. If omitted (or NULL), the

    ? --?????? ??????????????????user's own session is assumed

    ? --?? serial_num????????? - Session serial number for which SQL trace

    ? --???????????????????????? is enabled. If omitted (or NULL), only

    ? --???????????????????????? the session ID is used to determine a session

    ? --?? waits?????????????? - If TRUE, wait information will be present in the

    ? --???????????????????????? the trace

    ? --?? binds?????????????? - If TRUE, bind information will be present in the

    ? --???????????????????????? the trace

    ?

    ? PROCEDURE session_trace_disable(

    ??? session_id IN BINARY_INTEGER DEFAULT NULL ,

    ??? serial_num IN BINARY_INTEGER DEFAULT NULL );

    ?

    ? --? Disables SQL trace for the given Session ID

    ? --? Input arguments:

    ? --?? session_id????????? - Session Identifier for which SQL trace

    ? --???????????????????????? is disabled

    ? --?? serial_num????????? - Session serial number for which SQL trace

    ? --???????????????????????? is disabled

    ?

    ? PROCEDURE database_trace_enable(

    ??? waits IN BOOLEAN DEFAULT TRUE ,

    ??? binds IN BOOLEAN DEFAULT FALSE ,

    ??? instance_name IN VARCHAR2 DEFAULT NULL );

    ?

    ? --? Enables SQL trace for the whole database or given instance

    ? --? Input arguments:

    ? --?? waits?????????????? - If TRUE, wait information will be present in the

    ? --???????????????????????? the trace

    ? --?? binds?????????????? - If TRUE, bind information will be present in the

    ? --???????????????????????? the trace

    ? --?? instance_name?????? - if set, restricts tracing to the named instance

    ?

    ? PROCEDURE database_trace_disable(

    ??? instance_name IN VARCHAR2 DEFAULT NULL );

    ?

    ? --? Disables SQL trace for the whole database or given instance

    ? --? Input arguments:

    ? --?? instance_name?????? - if set, restricts disabling to the named instance

    end ;





    -The End-

    posted on 2009-04-13 22:26 decode360-3 閱讀(655) 評論(0)  編輯  收藏 所屬分類: Toy
    主站蜘蛛池模板: 国产亚洲福利精品一区二区| 国产亚洲精品美女久久久| 我的小后妈韩剧在线看免费高清版 | 无码乱人伦一区二区亚洲一| 亚洲成av人片天堂网老年人| 免费**毛片在线播放直播| 一区二区三区亚洲视频| 亚洲国产一区明星换脸| 久久精品亚洲福利| 亚洲精品午夜无码专区| 久久精品夜色国产亚洲av| 亚洲91av视频| 亚洲妓女综合网99| 亚洲综合色婷婷在线观看| 国产成人+综合亚洲+天堂| 一级毛片免费播放男男| 男人天堂免费视频| 亚洲最大免费视频网| 国产精品视频永久免费播放| 日韩一区二区免费视频| mm1313亚洲精品国产| 亚洲精品乱码久久久久久按摩 | 亚洲精品无码永久在线观看男男 | 亚洲av无码有乱码在线观看| 在线看亚洲十八禁网站| a级毛片免费网站| 特级精品毛片免费观看| 国产免费毛不卡片| 免费一级国产生活片| 亚洲精品无码永久在线观看你懂的| 西西人体44rt高清亚洲| ASS亚洲熟妇毛茸茸PICS| 精品视频免费在线| 成人无码a级毛片免费| 国产一卡2卡3卡4卡无卡免费视频| 大学生一级特黄的免费大片视频| 午夜亚洲国产成人不卡在线| 亚洲处破女AV日韩精品| 亚洲 欧洲 视频 伦小说| yellow视频免费看| 97国产免费全部免费观看|