[20200409]使用ash_wait_chains注意的一個細節.txt
[20200409]使用ash_wait_chains注意的一個細節.txt
--//上午使用ash_wait_chains檢查生產系統資料庫,遇到一個小問題做一個記錄:
> @ tpt/ash/ash_wait_chains upper(program2)||event2 1=1 trunc(sysdate) trunc(sysdate+1)
-- Display ASH Wait Chain Signatures script v0.2 BETA by Tanel Poder ( http://blog.tanelpoder.com )
%This SECONDS AAS WAIT_CHAIN
------ ---------- ------- -------------------------
33% 24518 .3 -> (XXXXXX.EXE) ON CPU
24% 17933 .2 -> (JNNN) ON CPU
22% 15984 .2 -> (WNWP.EXE) ON CPU
2% 1279 .0 -> (ORACLE) ON CPU
1% 1033 .0 -> () ON CPU
...
--//我想看看WNWP.EXE的sql語句.
> select * from gv$session where lower(program) like '%wnwp%';
no rows selected
--//找了半天也沒有找到這樣的程式。實際上程式是w3wp.exe.可以透過如下確定:
> @ tpt/ash/ash_wait_chains upper(program)||':'||event2 1=1 trunc(sysdate) trunc(sysdate+1)
-- Display ASH Wait Chain Signatures script v0.2 BETA by Tanel Poder ( http://blog.tanelpoder.com )
%This SECONDS AAS WAIT_CHAIN
------ ---------- ------- ------------------------------------
33% 25084 .3 -> XXXXXXX.EXE:ON CPU
24% 17886 .2 -> ORACLE@XXXXXXXX (J001):ON CPU
21% 16158 .2 -> W3WP.EXE:ON CPU
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1% 1043 .0 -> :ON CPU
--//實際上的執行程式是w3wp.exe.執行比較實際上指令碼把裡面的數字轉換成N。可以看出使用program2簡化program外,還做了一些處理。
--//主要目的是為了一些合併。可以檢視原始碼發現:
ash AS (SELECT /*+ QB_NAME(ash) LEADING(a) USE_HASH(u) SWAP_JOIN_INPUTS(u) */
a.*
, u.username
, CASE WHEN a.session_type = 'BACKGROUND' OR REGEXP_LIKE(a.program, '.*\([PJ]\d+\)') THEN
REGEXP_REPLACE(SUBSTR(a.program,INSTR(a.program,'(')), '\d', 'n')
ELSE
'('||REGEXP_REPLACE(REGEXP_REPLACE(a.program, '(.*)@(.*)(\(.*\))', '\1'), '\d', 'n')||')'
END || ' ' program2
, NVL(a.event||CASE WHEN a.event IN ('buffer busy waits', 'gc buffer busy', 'gc buffer busy acquire', 'gc buffer busy release')
THEN ' ['||(SELECT class FROM bclass WHERE r = a.p3)||']' ELSE null END,'ON CPU')
|| ' ' event2
, TO_CHAR(CASE WHEN session_state = 'WAITING' THEN p1 ELSE null END, '0XXXXXXXXXXXXXXX') p1hex
, TO_CHAR(CASE WHEN session_state = 'WAITING' THEN p2 ELSE null END, '0XXXXXXXXXXXXXXX') p2hex
, TO_CHAR(CASE WHEN session_state = 'WAITING' THEN p3 ELSE null END, '0XXXXXXXXXXXXXXX') p3hex
FROM
gv$active_session_history a
, dba_users u
WHERE
a.user_id = u.user_id (+)
AND sample_time BETWEEN &3 AND &4
),
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2685119/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- JavaScript初學者應注意的七個細節JavaScript
- android Activity細節(一) onSaveInstanceState()方法使用注意點Android
- 你需要注意的Java小細節(一)Java
- WAS 開發需要注意的一些細節
- Golang陣列注意細節Golang陣列
- QT小小細節注意點QT
- Laravel 的一個命名細節分享Laravel
- 一個小的技術細節
- UITextField使用的一些細節UI
- Termux使用的一些細節UX
- Java面試要注意哪些細節Java面試
- Java泛型應該注意的細節Java泛型
- Docker 19.03.13的四個使用細節Docker
- [20140702]linux使用dd的一些細節.txtLinux
- 使用JavaScript變數需要注意哪些語法細節?JavaScript變數
- 使用Bootstrap v3.3.4注意細節box-sizingboot
- [譯] Google JavaScript 風格指南中 13 個值得注意的細節GoJavaScript
- 企業建站的相關注意細節分享
- 實施“番茄工作法”需要注意的一些細節
- 用 Go map 要注意這 1 個細節,避免依賴他!Go
- Git 的一些使用細枝末節Git
- Oracle兩個使用細節知識點Oracle
- 集合:安卓開發中怎麼注意細節?一文告訴你四十個安卓
- 不被注意的細節WiFi密碼暗藏巨大隱患WiFi密碼
- [JAVA] Java switch的使用細節Java
- iOS中使用UICollectionView的細節iOSUIView
- 程式設計師面試 IT 公司,這些細節一定要注意!程式設計師面試
- [20120327]toad與sqlplus下執行sql語句的一個細節.txtSQL
- Node 中如何引入一個模組及其細節
- 搭建直播系統前需要注意的細節有哪些?
- 乾貨 | APP介面設計的色彩注意細節,有哪些?APP
- Android CardView 開發過程中要注意的細節AndroidView
- OpenFeign 使用細節
- 一個MapReduce 程式示例 細節決定成敗(一)
- MYSQL索引建立需要注意以下幾點細節MySql索引
- TCP 中的兩個細節點TCP
- Struts2中 用OGNL表示式定義字串常量 與單個字元常量需要注意的一個小細節 (轉)...字串字元
- vue元件使用的細節 is 屬性Vue元件