国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
Oracle 10g實(shí)用程序trcsess:跟蹤sql語(yǔ)句 - Oracle - IT學(xué)習(xí)...
在診斷數(shù)據(jù)庫(kù)系統(tǒng)性能的過(guò)程中,總會(huì)涉及到跟蹤效率低下的sql語(yǔ)句,Oracle數(shù)據(jù)庫(kù)10g包含一種新的實(shí)用程序trcsess,它可以讓您基于會(huì)話ID或模塊名稱之類的條件,有選擇地從大量跟蹤文件中抽取出跟蹤數(shù)據(jù),并將它們保存到一個(gè)文件中。該實(shí)用程序在共享服務(wù)器配置中特別有用,因?yàn)檎{(diào)度程序可能把每一個(gè)用戶請(qǐng)求傳遞給不同的共享服務(wù)器進(jìn)程,從而為任何給定的會(huì)話產(chǎn)生多個(gè)跟蹤文件。與通過(guò)大量跟蹤文件發(fā)掘信息不同,Oracle數(shù)據(jù)庫(kù)10g的trcsess可以讓您獲得關(guān)于單一用戶會(huì)話的整合后的跟蹤信息?,F(xiàn)在就如何跟蹤sql語(yǔ)句來(lái)做一個(gè)簡(jiǎn)單的總結(jié)。權(quán)做拋磚引玉之用。如果我們可以修改應(yīng)用系統(tǒng)的源代碼,則可以直接在程序中加入如下的語(yǔ)句:
1)alter session set timed_statistics=true; /*適用于Oracle 8.1.7以后的版本*/ 2)alter session set max_dump_file_size=unlimited ; /*適用于Oracle 9i以后的版本*/ 3)alter session set tracefile_identifier='POX20031031a'; /*適用于Oracle 9i以后的版本*/ 4)alter session set events '10046 trace name context forever, level 8'; /*在這里編寫(xiě)應(yīng)用程序的代碼*/ 5)alter session set events '10046 trace name context off';
在上述語(yǔ)句中,語(yǔ)句1)是把該會(huì)話的時(shí)間統(tǒng)計(jì)打開(kāi),該參數(shù)默認(rèn)為false.在Oracle 9i之前的版本中,不能在會(huì)話級(jí)設(shè)置該參數(shù),只能修改初始化文件然后重新啟動(dòng)數(shù)據(jù)庫(kù),這樣將在實(shí)例級(jí)打開(kāi)時(shí)間統(tǒng)計(jì)。
語(yǔ)句2)是把跟蹤文件的大小設(shè)置成操作系統(tǒng)所允許的最大尺寸,這樣可以防止跟蹤文件在完成所需要的跟蹤之前被填充滿,此外需要注意的是確保存放跟蹤文件的目錄要有足夠的空間,否則將會(huì)收到“文件系統(tǒng)已滿”錯(cuò)誤。
語(yǔ)句3)的作用是使生成的跟蹤文件名稱中包含'POX20031031a'字符串,這樣可以使你很容易的找到所需的跟蹤文件,該參數(shù)在Oracle 9i之后可用。
語(yǔ)句4)和語(yǔ)句5)的作用分別是打開(kāi)和關(guān)閉跟sql跟蹤,你可以在這兩個(gè)語(yǔ)句之間寫(xiě)入應(yīng)用程序的代碼,這些代碼的執(zhí)行情況都將被跟蹤。需要注意的是語(yǔ)句4)的level關(guān)鍵字,它用來(lái)指定跟蹤級(jí)別,一共有0,1,2,4,8,12六個(gè)級(jí)別可以設(shè)置,0相當(dāng)于關(guān)閉跟蹤;1是輸出一般的跟蹤信息,不包括綁定變量和等待信息;2和1相同;4是在級(jí)別1的基礎(chǔ)上增加綁定變量信息;8是在級(jí)別1的基礎(chǔ)上增加等待信息;級(jí)別12是輸出包含級(jí)別1,4,8的所有信息。
如果應(yīng)用程序的代碼無(wú)法修改或者是不想去修改,則可以在其他會(huì)話中打開(kāi)對(duì)特定會(huì)話的跟蹤,方法如下:
1)sys.dbms_system.set_bool_param_in_session(:sid, :serial,'timed_statistics', true); 2)sys.dbms_system.set_int_param_in_session( :sid, :serial,'max_dump_file_size', 2147483647); 打開(kāi)和關(guān)閉跟蹤的第一種方法(oracle推薦): 3.1)sys.dbms_support.start_trace_in_session(:sid, :serial,waits=>true, binds=>false); /* 在此期間運(yùn)行要跟蹤的應(yīng)用程序*/ 4.1)sys.dbms_support.stop_trace_in_session(:sid, :serial); 打開(kāi)和關(guān)閉跟蹤的第二種方法: 3.2)sys.dbms_system.set_ev(:sid, :serial, 10046, 8, ''); /*在此期間運(yùn)行要跟蹤的應(yīng)用程序*/ 3.2)sys.dbms_system.set_ev(:sid, :serial, 10046, 0, '');
以上語(yǔ)句中的:sid和:serial分別代表所要跟蹤的會(huì)話的ID和序列號(hào),這些信息可以從V$SESSION視圖的SID和SERIAL#列獲得。打開(kāi)關(guān)閉跟蹤中第一種方法的好處是你不用自己寫(xiě)10046這個(gè)事件號(hào),這樣可以減少錯(cuò)誤,但是dbms_support程序包在你的數(shù)據(jù)庫(kù)中可能會(huì)不存在,這樣就只有用第二種方法了。
到現(xiàn)在為止,我們已經(jīng)生成了所需要的跟蹤文件,然后我們需要找到該文件來(lái)進(jìn)行分析。跟蹤文件的存放位置只有兩種可能,Oracle參數(shù)USER_DUMP_DEST 或者BACKGROUND_DUMP_DEST指定的目錄;文件名稱根據(jù)不同的平臺(tái)會(huì)有所不同,但是在文件名中都會(huì)包含會(huì)話所對(duì)應(yīng)的操作系統(tǒng)進(jìn)程(線程)號(hào),也就是V$PROCESS的SPID列(V$PROCESS.SPID) ,該信息可以通過(guò) v$process.addr和v$session.paddr做表連接查詢得到。例如:
select spid from v$process p,
v$session s where p.addr=s.paddr and s.sid=:sid and s.serial#=:serial.
本文只對(duì)Oracle在使用專用服務(wù)器進(jìn)程(Dedicated Server)模式做了總結(jié),至于的共享服務(wù)器(Shared Server)模式和在應(yīng)用級(jí)使用連接池的情況下,收集sql跟蹤信息的方法會(huì)比較復(fù)雜,希望有相關(guān)經(jīng)驗(yàn)的高手來(lái)總結(jié)。
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)
打開(kāi)APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
查詢Oracle正在執(zhí)行的sql語(yǔ)句
Oracle 10g:用等待界面診斷性能問(wèn)題
獲取、閱讀執(zhí)行計(jì)劃
oracle系統(tǒng)表v$session、v$sql字段說(shuō)明
45 個(gè)非常有用的 Oracle 查詢語(yǔ)句
Oracle V$SESSION詳解
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服