<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • 如何在Oracle數(shù)據(jù)庫10g中跟蹤SQL

    時間:2024-07-13 10:22:13 Oracle認證 我要投稿
    • 相關推薦

    如何在Oracle數(shù)據(jù)庫10g中跟蹤SQL

      在具有許多活躍用戶的繁忙生產(chǎn)環(huán)境中,跟蹤SQL會話是費時且十分復雜的,因為在任何使用連接池的多層系統(tǒng)中處理SQL語句可能要涉及多個進程,或者甚至是不同的實例。

      利用Oracle數(shù)據(jù)庫10g,Oralce通過一個新的內置軟件包DBMS_MONITOR合理化了SQL的跟蹤,這個軟件包中包含以前無書面記載的跟蹤工具(如DBMS_SUPPORT軟件包)的功能。現(xiàn)在,您可以輕松地從頭到尾--從客戶機到中間層再到后端--跟蹤任何用戶的會話,并且基于特定的客戶ID、模塊或動作生成跟蹤文件。

      此外,Oracle數(shù)據(jù)庫10g包含一種新的實用程序trcsess,它可以讓您基于會話ID或模塊名稱之類的條件,有選擇地從大量跟蹤文件中抽取出跟蹤數(shù)據(jù),并將它們保存到一個文件中。該實用程序在共享服務器配置中特別有用,因為調度程序可能把每一個用戶請求傳遞給不同的共享服務器進程,從而為任何給定的會話產(chǎn)生多個跟蹤文件。與通過大量跟蹤文件發(fā)掘信息不同,Oracle數(shù)據(jù)庫10g的trcsess可以讓您獲得關于單一用戶會話的整合后的跟蹤信息。

      開始

      和Oracle數(shù)據(jù)庫的以前版本一樣,跟蹤文件將被輸出到由服務器的初始化文件(或spfile)的user_dump_dest參數(shù)指定的目錄中。默認的位置取決于操作系統(tǒng);例如,對于使用DBCA的Microsoft Windows平臺,默認位置是$ORACLE_BASE\instance_name\admin\udump,其中instance_ name是Oracle實例的名稱。您可以通過使用以下改變會話命令來動態(tài)地更改該參數(shù):

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

      您還可以把您自己的標記添加到跟蹤文件名中,以便您能夠更容易地找到生成的文件。為此,可以在啟動跟蹤之前設置tracefile_identifier初始化參數(shù):

    alter session set 
    tracefile_identifier ="kfloss_test";

      通過該命令生成的跟蹤文件帶有您設置的附加在文件名后的字符串值。盡管這些改變會話命令都不是必要的,但是它們都會使查找跟蹤會話的結果更容易。

      現(xiàn)在,我們已經(jīng)設置了這些參數(shù),那么讓我們看看新的跟蹤軟件包和Oracle企業(yè)管理器的界面。讓我們使用新的DBMS_MONITOR軟件包通過模塊名稱和客戶機名稱來建立一個跟蹤。

      用DBMS_MONITOR建立跟蹤

      DBMS_MONITOR包具有多個例程,用于啟用和禁用統(tǒng)計數(shù)據(jù)集合,以及用于根據(jù)會話ID進行跟蹤、或者基于服務名稱、模塊名稱和動作名稱的組合進行跟蹤。(它們三者從層次結構上是關聯(lián)的:您不能在不指定模塊和服務名稱的情況下指定一個動作,但是您可以只指定服務名稱,或者只指定服務名稱和模塊名稱)。 模塊名稱和動作名稱(如果有的話)都來自于應用程序代碼內部。例如,Oracle電子商務套件應用程序在代碼中提供了模塊名稱和動作名稱,這樣您就可以在任何Oralce企業(yè)管理器頁面中通過名稱來識別它們。 (PL/SQL開發(fā)人員可以通過使用DBMS_APPLICATION_INFO包設置模塊名稱和動作名稱,把一些調用嵌入到他們的應用程序中)。

      請注意,設置模塊、動作及其他參數(shù)(如client_id)將不造成對數(shù)據(jù)庫的往返操作--這些例程攜帶來自應用程序的所有調用。

      服務名稱由用于連接該服務的連接字符串來確定。未與特定服務關聯(lián)的用戶會話將由sys$users處理(sys$background是后臺進程的默認服務)。由于我們具有一個服務和一個模塊名稱,因而我們可以啟動對該模塊的跟蹤,如下所示:

    SQL> exec dbms_monitor.serv_mod_act_trace_enable
    (service_name=>'testenv', module_name=>'product_update');

      PL/SQL過程已成功完成。

      我們可以啟動對客戶機的跟蹤:

    SQL> exec dbms_monitor.client_id_trace_enable
    (client_id=>'kimberly');

      PL/SQL過程已成功完成。

      請注意,所有這些設置都是永久性的--所有與該服務和模塊關聯(lián)的會話都會被跟蹤,而不僅僅是跟蹤當前會話。

      為了基于會話ID跟蹤SQL,可以查看Oracle企業(yè)管理器的Top Sessions頁面,或者像您當前做的那樣查詢V$SESSION視圖。

    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.

      通過會話ID(SID)和序號,您可以使用DBMS_MONITOR只對下面的會話啟用跟蹤:

      SQL> exec dbms_monitor.session_trace_enable(139);

      PL/SQL過程已成功完成。

      該序號默認為該SID的當前序號(除非另外指定),因此如果那就是您想跟蹤的會話和序號,那么您就不必查看更多的內容了。還有,默認情況下,WAITS設置為true而BINDS設置為false,因此上面的語法實際上與下面的語法效果相同:

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

      請注意,WAITS和BINDS是相同的參數(shù),您在過去可能已經(jīng)使用DBMS_SUPPORT和10046事件對它們進行了設置。

      如果您正在一個生產(chǎn)環(huán)境中工作,那么此時您最好重新運行出錯的SQL或應用程序,并且相應地創(chuàng)建跟蹤文件。

      用企業(yè)管理器建立跟蹤

      通過Oracle企業(yè)管理器建立跟蹤從Top Consumers頁面(可以通過Additional Monitoring Links區(qū)域中的Performance頁面得到,如圖1所示)開始。該頁面顯示服務、模塊、客戶和動作對系統(tǒng)資源的當前使用情況。

      圖1:Oracle企業(yè)管理器的Top Consumers頁面

      您可以單擊Top Services、Top Modules、Top Actions、Top Clients或Top Sessions選項卡,來查看這些類別的頂級消費者中每一種的詳細信息,隨后您可以通過這些頁面中的每一個頁面輕松啟用(或禁用)SQL跟蹤。從頁面上的列表中簡單地選擇項目,然后單擊啟用SQL跟蹤(Enable SQL Trace)開始跟蹤(當您完成跟蹤時,單擊禁用按鈕)。

      您還可以啟用(或禁用)這些頁面上列出的任何項目的統(tǒng)計數(shù)據(jù)集合。(DBMS_MONITOR還提供了用于啟用和禁用數(shù)據(jù)集合的例程)。

      分析跟蹤結果

      獲取關于Kimberly Floss的圖書的信息

      無論您是使用DBMS_MONITOR或者是使用Oracle企業(yè)管理器建立跟蹤,您都將使用trcsess 命令行工具來整合跟蹤文件。單擊Oracle企業(yè)管理器中的查看SQL跟蹤(View SQL Trace)按鈕顯示一個頁面,其中顯示了您將用于整合所有跟蹤文件的語法。

      要確保用雙引號括住字符串,并在文件名后添加一個".trc"擴展名;否則,TKPROF將不會把它作為一個文件名來接受。在執(zhí)行該命令之前,找到在user_dump_dest(或者,如果您沒有更改該參數(shù)名,則在\udump)中指定的目錄。

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

      隨后,您可以對整合的跟蹤文件運行TKPROF,以生成一份報告。

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

      如果您不終止跟蹤,那么運行該服務和模塊的每一個會話都會被跟蹤。因此,當您完成跟蹤時,要確保通過使用Oralce企業(yè)管理器或DBMS_MONITOR包來終止跟蹤。

    【如何在Oracle數(shù)據(jù)庫10g中跟蹤SQL】相關文章:

    oracle的sql語句09-03

    Oracle的sql語句模擬試題及答案10-12

    ORACLE 常用的SQL語法和數(shù)據(jù)部分06-22

    Oracle數(shù)據(jù)庫語句大全10-08

    ORACLE數(shù)據(jù)庫碎片的整理08-18

    oracle數(shù)據(jù)庫基本語句08-21

    Oracle數(shù)據(jù)庫認證層次08-29

    Oracle數(shù)據(jù)庫的基本介紹09-04

    Oracle數(shù)據(jù)庫SQLPLUS介紹10-09

    Oracle數(shù)據(jù)庫SELECT語句10-25

    主站蜘蛛池模板: 国产精品无码av在线播放| 99国产欧美久久久精品蜜芽| 精品无码国产自产拍在线观看| 亚洲国产成人久久精品影视| 日韩精品无码久久久久久| 精品综合久久久久久88小说| japanese乱人伦精品| 中日精品无码一本二本三本| 久久国产香蕉一区精品| 99久久精品国产一区二区三区 | 亚洲精品无码国产| 久久99精品久久久久久噜噜| 亚洲国产精品第一区二区| 99精品无人区乱码在线观看| 无码人妻精品一区二区三区66 | 日本Aⅴ大伊香蕉精品视频 | 国内精品99亚洲免费高清| 99精品欧美一区二区三区| 精品视频一区二区三区免费| 国产色婷婷五月精品综合在线| 日产精品久久久久久久性色| 中文字幕精品视频在线| 亚洲精品二三区| 亚洲精品国精品久久99热一| 亚洲精品老司机在线观看| 人妻无码精品久久亚瑟影视| 日韩AV毛片精品久久久| 久久国产精品免费一区二区三区 | 成人午夜精品视频在线观看| 久久久久99精品成人片试看 | 精品视频无码一区二区三区| 久久精品人人做人人妻人人玩| 人人妻人人澡人人爽人人精品97| 中文字幕无码久久精品青草| 欧美日韩精品久久久久| 四虎永久在线精品884aa下载| 国产精品青草久久久久婷婷| 国产精品视频久久久| 精品精品国产自在久久高清| 亚洲精品成人av在线| 国产精品va久久久久久久|