摘要:提供以作業基本單位的作業統計視圖pgxc_session_wlmstat,便于用戶觀察運行作業和排隊作業資訊,
本文分享自華為云社區《GaussDB(DWS)如何查看作業運行資訊》,作者:幕后小黑爪,
用戶反饋,出現連接數告警,作業并發數高,超過資源池限制,與實際配置不符,經過了解,用戶使用pgxc_stat_activity視圖進行作業并發數判斷,
該視圖顯示用戶查詢相關資訊,是以連接執行緒為基礎來進行統計的,因而使用此視圖進行查詢會存在幾個問題:
- 實際現網環境中,用戶使用的是第三方工具連接的資料庫,這些工具為了提高運行效率,會先建立連接,在下發作業,作業執行完成后回傳,再下發作業運行,直到作業全部執行完成,才會斷開連接,這樣就導致pgxc_stat_activity會殘留上次作業運行的資訊,記錄不準,
- 該視圖中包含大量內部執行緒資訊,如內部連接(CN-CN),這種連接已經在主CN管控過,所以理論上不需要管控,但是pgxc_stat_activity會進行記錄,導致顯示的活躍會話數增多,造成從pgxc_stat_activity視圖中的并發數超限的現象,
為此,我們提供以作業基本單位的作業統計視圖pgxc_session_wlmstat,便于用戶觀察運行作業和排隊作業資訊,以下給出推薦的查詢陳述句,
注:該視圖在GaussDB(DWS)8.1.3以上版本生效,且用戶需要關閉guc引數enable_gtm_free,如果該引數開啟,會存在統計不準確情況,
引數欄位說明
pgxc_session_wlmstat中欄位說明:
1)陳述句當前的狀態status,包括:
- pending:執行前狀態,
- running:執行進行狀態,、
- finished:執行正常結束,(當enqueue欄位為 StoredProc或Transaction時,僅代表陳述句中的部 分作業已經執行完畢,該狀態會持續到該陳述句完全執行完畢,)
- aborted:執行例外終止,
- active: 非以上四種狀態外的正常狀態,
- unknown: 未知狀態,
1)陳述句的屬性attribute
- Ordinary:陳述句發送到資料庫后被決議前的默認 屬性,
- Simple:簡單陳述句,
- Complicated:復雜陳述句,
- Internal:資料庫內部陳述句,
1 分CN查詢結果:
1.1 分CN查詢用戶的作業運行與排隊統計:
select nodename,usename, enqueue,status,count(1) as query_count,sum(statement_mem) as estimate_mem from pgxc_session_wlmstat where status in ('pending','running') and attribute!='Internal' and usename!='Ruby' and usename <> 'omm' group by 1,2,3,4 limit 100;
查詢結果如下:
1.2 分CN查詢用戶作業運行與排隊詳細資訊
如果需要其他資訊也可從pgxc_session_wlmstat和pgxc_stat_activity中進行獲取
select s.nodename, s.resource_pool,s.usename, a.query_start, s.enqueue,s.status, substr(s.query,1,30) as query, statement_mem as estimate_mem,a.query_id from pgxc_session_wlmstat s, pgxc_stat_activity a where s.threadid=a.pid and status in ('pending','running') and s.attribute!='Internal' and s.usename!='Ruby' and s.usename <> 'omm' order by 1,2,3,5,6 limit 100;
查詢結果如下:
1.3 分CN查詢資源池內的作業運行與排隊統計資訊
select resource_pool,nodename, enqueue,status,count(1) as query_count,sum(statement_mem) as estimate_mem from pgxc_session_wlmstat where status in ('pending','running') and attribute!='Internal' and usename!='Ruby' and usename <> 'omm' group by 1,2,3,4 limit 100;
查詢結果如下:
2 集群整體查詢
2.1 整個集群用戶的作業運行和排隊統計
select usename, enqueue,status,count(1) from pgxc_session_wlmstat where status in ('pending','running') and attribute!='Internal' and usename!='Ruby' and usename <> 'omm' group by 1,2,3 limit 100;
查詢結果如下:
2.2 整個集群查詢用戶作業運行與排隊詳細資訊
select s.resource_pool,s.usename, a.query_start, s.enqueue,s.status, substr(s.query,1,30) as query, statement_mem as estimate_mem,a.query_id from pgxc_session_wlmstat s, pgxc_stat_activity a where s.threadid=a.pid and status in ('pending','running') and s.attribute!='Internal' and s.usename!='Ruby' and s.usename <> 'omm' order by 1,2,4,5 limit 100;
查詢結果如下:
2.3 整個集群資源池內的作業運行與排隊統計資訊
select resource_pool, enqueue,status,count(1) as query_count,sum(statement_mem) as estimate_mem from pgxc_session_wlmstat where status in ('pending','running') and attribute!='Internal' and usename!='Ruby' and usename <> 'omm' group by 1,2,3 limit 100;
查詢結果如下:
2.4 整個集群資源池內的作業運行和排隊的統計資訊
SELECT s.resource_pool AS rpname, COUNT(1) AS session_cnt,SUM(CASE WHEN a.state = 'active' THEN 1 ELSE 0 END) AS active_cnt,SUM(CASE WHEN s.enqueue ='Global' THEN 1 ELSE 0 END) AS global_wait,SUM(CASE WHEN s.lane = 'fast' and s.status = 'running' THEN 1 ELSE 0 END) AS fast_run,SUM(CASE WHEN s.lane = 'fast' and s.status = 'pending' and s.enqueue not in ('Global','None') THEN 1 ELSE 0 END) AS fast_wait,SUM(CASE WHEN s.lane = 'slow' and s.status = 'running' THEN 1 ELSE 0 END) AS slow_run,SUM(CASE WHEN s.lane = 'slow' and s.status = 'pending' and s.enqueue not in ('Global','None') THEN 1 ELSE 0 END) AS slow_wait,SUM(CASE WHEN s.status = 'running' THEN s.statement_mem ELSE 0 END) AS est_mem FROM pg_catalog.pgxc_session_wlmstat s,pg_catalog.pgxc_stat_activity a WHERE s.threadid=a.pid(+) AND s.attribute != 'Internal' AND s.resource_pool != 'root' GROUP BY 1;
查詢結果如下:


7月7日,華為開發者大會2023 ( Cloud )將拉開帷幕,并將在國內30多個城市、海外10多個國家開設分會場,誠邀您參加這場不容錯過的年度開發者盛會,讓我們一起開啟探索之旅!
我們將攜手開發者、客戶、合作伙伴,為您呈現華為云系列產品服務與豐富的創新實踐,并與您探討AI、大資料、資料庫、PaaS、aPaaS、媒體服務、云原生、安全、物聯網、區塊鏈、開源等技識訓題,展開全面深入的交流,
大會將匯聚全球科學家、行業領袖、技術專家、社區大咖,開設200多場開發者專題活動,為全球開發者提供面對面交流與合作的機會,共同探討技術創新和業務發展,
大會官網:https://developer.huaweicloud.com/HDC.Cloud2023.html
參會購票:https://www.vmall.com/product/10086352254099.html?cid= 211761
點擊參與開發者社區活動,觀賞技術大咖秀、玩轉技術夢工廠,有機會贏取4000元開發者禮包!
歡迎關注“華為云開發者聯盟”公眾號,獲取大會議程、精彩活動和前沿干貨,
點擊關注,第一時間了解華為云新鮮技術~
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/555231.html
標籤:其他
下一篇:返回列表
