GaussDB(DWS)查詢過(guò)濾器原理與應(yīng)用 每日熱文
摘要:GaussDB(DWS)查詢過(guò)濾器(黑名單)提供查詢過(guò)濾功能,支持自動(dòng)隔離反復(fù)被終止的查詢,防止?fàn)€SQL再次執(zhí)行。
本文分享自華為云社區(qū)《GaussDB(DWS)查詢過(guò)濾器原理與應(yīng)用》,作者:門(mén)前一棵葡萄樹(shù) 。
【資料圖】
一、概述
GaussDB(DWS)查詢過(guò)濾器(黑名單)提供查詢過(guò)濾功能,支持自動(dòng)隔離反復(fù)被終止的查詢,防止?fàn)€SQL再次執(zhí)行。
主要應(yīng)用場(chǎng)景包含以下兩種:
1. 異常熔斷機(jī)制
配置異常規(guī)則后,查詢觸發(fā)異常規(guī)則后,異常信息將被記錄在dbms_om.gs_blocklist_query系統(tǒng)表中。同一個(gè)查詢觸發(fā)異常規(guī)則次數(shù)超限(query_exception_count_limit)后,查詢自動(dòng)加入黑名單,黑名單信息同樣保存在dbms_om.gs_blocklist_query系統(tǒng)表中。加入黑名單后,該查詢將被隔離,拒絕執(zhí)行。
2. 緊急攔截
作業(yè)引發(fā)CORE、hang或性能大幅下降等問(wèn)題時(shí),需要緊急規(guī)避時(shí),可以將作業(yè)加入黑名單進(jìn)行過(guò)濾。
原理介紹
查詢過(guò)濾器使用作業(yè)Unique SQL ID保存和識(shí)別作業(yè)黑名單和異常信息,在SQL中常數(shù)值發(fā)生變化時(shí)作業(yè)Unique SQL ID不會(huì)隨之發(fā)生變化。Unique SQL ID是遍歷查詢解析樹(shù)計(jì)算出來(lái)的一個(gè)整數(shù)值,用于標(biāo)識(shí)一類SQL。通常對(duì)于DML語(yǔ)句,在計(jì)算Unique SQL ID的過(guò)程中會(huì)忽略常量值。但對(duì)于DDL、DCL以及設(shè)置參數(shù)等語(yǔ)句,常量值不會(huì)忽略。例如,以下兩個(gè)查詢:
select * from t1 where id = 1;select * from t1 where id = 2;
這兩條SQL除過(guò)濾條件中的常量不同外,其他全部相同,由此生成的解析樹(shù)拓?fù)渫耆嗤虼薝nique SQL ID相同。Unique SQL ID的計(jì)算只會(huì)忽略常數(shù)值,而不會(huì)忽略其他差異,SQL語(yǔ)句“select * from t2 where id = 1;”與上述兩個(gè)SQL的Unique SQL ID就不相同。
將作業(yè)加入黑名單主要有以下兩種方式:
- 在GUC參數(shù)query_exception_count_limit≥0情況下,作業(yè)觸發(fā)異常次數(shù)超過(guò)該閾值后自動(dòng)將作業(yè)加入黑名單;
- 調(diào)用內(nèi)置函數(shù)gs_append_blocklist(unique_sql_id int8)將作業(yè)加入黑名單。
作業(yè)執(zhí)行前判斷作業(yè)是否在黑名單中,如果作業(yè)在黑名單中,拒絕作業(yè)執(zhí)行,直接報(bào)錯(cuò)退出。
作業(yè)被拒絕執(zhí)行后,對(duì)作業(yè)加入黑名單原因進(jìn)行分析,問(wèn)題解決后調(diào)用內(nèi)置函數(shù)gs_remove_blocklist(unique_sql_id int8)將作業(yè)移除黑名單。
二、應(yīng)用示例
2.1 異常熔斷示例
1. 設(shè)置異常熔斷閾值。假設(shè)設(shè)置query_exception_count_limit=1,即只要作業(yè)觸發(fā)異常規(guī)則作業(yè)就會(huì)被加入黑名單。
2. 配置異常規(guī)則
創(chuàng)建CPU平均使用率異常規(guī)則cpu_percent_except,作業(yè)運(yùn)行時(shí)間超過(guò)2000秒且CPU使用率達(dá)到30%時(shí)觸發(fā)異常退出:
CREATE EXCEPT RULE cpu_percent_except WITH(ELAPSEDTIME=2000, CPUAVGPERCENT=30);
異常規(guī)則還支持BLOCKTIME、ALLCPUTIME、SPILLSIZE等異常的識(shí)別處理,具體可參考:異常規(guī)則簡(jiǎn)介與演變。
3. 創(chuàng)建資源池respool1關(guān)聯(lián)異常規(guī)則cpu_percent_except。
CREATE RESOURCE POOL respool1 WITH(except_rule="cpu_percent_except");
資源池支持最多關(guān)聯(lián)63個(gè)異常規(guī)則集,每個(gè)異常規(guī)則集間獨(dú)立生效,互不影響。
4. 創(chuàng)建業(yè)務(wù)用戶usr1,關(guān)聯(lián)資源池respool1:
CREATE USER usr1 RESOURCE POOL "respool1" PASSWORD "XXXXXX";
5. 用戶usr1運(yùn)行作業(yè),作業(yè)運(yùn)行時(shí)間超過(guò)2000秒且CPU使用率達(dá)到30%時(shí)觸發(fā)“cpu_percent_except”異常規(guī)則,作業(yè)觸發(fā)異常規(guī)則后資源管理對(duì)作業(yè)進(jìn)行以下處理:
- 將作業(yè)異常信息保存至系統(tǒng)表GS_BLOCKLIST_QUERY中;
- 如果作業(yè)觸發(fā)異常熔斷,將系統(tǒng)表GS_BLOCKLIST_QUERY中作業(yè)黑名單標(biāo)志置為true;
- 更新GS_BLOCKLIST_QUERY中作業(yè)黑名單信息。
6. 查詢作業(yè)黑名單和異常信息:
SELECT * FROM dbms_om.gs_blocklist_query; unique_sql_id | block_list | except_num | except_time---------------+------------+------------+---------------------------- 4066836196 | t | 1 | 2022-08-08 18:00:00.596269(1 row)
7. 用戶usr1再次運(yùn)行作業(yè)觸發(fā)異常熔斷,GaussDB(DWS)的異常熔斷機(jī)制禁止該作業(yè)執(zhí)行。
ERROR: The query is in the blocklist and cannot be run, unique_sql_id(4066836196).HINT: If you want to run the query later, confirm the reason why the query is blocklisted and remove the query from the blocklist after resolving the problem.
8. 優(yōu)化用戶usr1所運(yùn)行ID為4066836196的SQL后,將ID為4066836196的SQL從黑名單移除。
確認(rèn)SQL異常原因,如果異常規(guī)則配置不合理,修改異常規(guī)則;如果異常規(guī)則合理,對(duì)SQL進(jìn)行優(yōu)化后重新運(yùn)行。確認(rèn)問(wèn)題解決后將SQL移除黑名單。
select gs_remove_blocklist(4066836196); gs_remove_blocklist--------------------- t(1 row)
2.2 緊急攔截示例
查詢過(guò)濾器使用作業(yè)Unique SQL ID識(shí)別和保存黑名單信息,為有效運(yùn)用查詢過(guò)濾器緊急攔截功能,建議TopSQL開(kāi)啟,在作業(yè)引發(fā)CORE、報(bào)錯(cuò)、性能下降等問(wèn)題時(shí)可以快速獲取作業(yè)Unique SQL ID。
2.2.1 獲取作業(yè)Unique SQL ID
獲取作業(yè)Unique SQL ID的幾種方法:
1. 作業(yè)引發(fā)報(bào)錯(cuò)/性能下降
CN日志中獲取作業(yè)query_id,執(zhí)行以下命令查詢作業(yè)Unique SQL ID。
select queryid,unique_sql_id,query from pgxc_wlm_session_info where queryid=query_id;
2. 作業(yè)引發(fā)CN示例CORE
解析CORE打印內(nèi)存中保存的Unique SQL ID對(duì)應(yīng)的變量參數(shù)值。
3. 作業(yè)引發(fā)DN實(shí)例CORE
作業(yè)引發(fā)DN實(shí)例CORE時(shí),CN側(cè)體現(xiàn)為作業(yè)報(bào)錯(cuò),Unique SQL ID獲取方式可以參考作業(yè)報(bào)錯(cuò)時(shí)Unique SQL ID獲取方式。
4. EXPLAIN VERBOSE獲取Unique SQL ID(通用方法,但是僅821及以上版本支持)
EXPLAIN VERBOSE不會(huì)實(shí)際執(zhí)行SQL,因此一般不會(huì)導(dǎo)致問(wèn)題發(fā)生,使用EXPLAIN VERBOSE XXX;可以打印得到作業(yè)Unique SQL ID。示例:
postgres=# explain verbose select count(1) from pg_class; QUERY PLAN------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- id | operation | E-rows | E-distinct | E-width | E-costs ----+----------------------------------------+--------+------------+---------+--------- 1 | -> Aggregate | 2 | | 8 | 52.94 2 | -> Seq Scan on pg_catalog.pg_class | 1034 | | 0 | 50.34 Targetlist Information (identified by plan id) ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 1 --Aggregate Output: count(1) 2 --Seq Scan on pg_catalog.pg_class Output: relname, relnamespace, reltype, reloftype, relowner, relam, relfilenode, reltablespace, relpages, reltuples, relallvisible, reltoastrelid, reltoastidxid, reldeltarelid, reldeltaidx, relcudescrelid, relcudescidx, relhasindex, relisshared, relpersistence, relkind, relnatts, relchecks, relhasoids, relhaspkey, relhasrules, relhastriggers, relhassubclass, relcmprs, relhasclusterkey, relrowmovement, parttype, relfrozenxid, relacl, reloptions, relreplident, relfrozenxid64 ====== Query Summary ===== -------------------------- Parser runtime: 0.027 ms Planner runtime: 0.561 ms Unique SQL Id: 2307078791(17 rows)
2.2.2 將作業(yè)加入黑名單
獲取到作業(yè)Unique SQL ID后,調(diào)用內(nèi)置函數(shù)gs_append_blocklist(unique_sql_id int8)將作業(yè)加入黑名單:
postgres=# select * from gs_append_blocklist(2307078791); gs_append_blocklist--------------------- t(1 row)
2.2.3 查詢黑名單信息
作業(yè)加入黑名單后,查詢系統(tǒng)表確認(rèn)黑名單加入是否成功:
postgres=# SELECT * FROM dbms_om.gs_blocklist_query; unique_sql_id | block_list | except_num | except_time---------------+------------+------------+------------- 2307078791 | t | 0 |(1 row)
2.2.4 再次執(zhí)行作業(yè)觸發(fā)緊急攔截
postgres=# select count(1) from pg_class;ERROR: The query is in the blocklist and cannot be run, unique_sql_id(2307078791).HINT: If you want to run the query later, confirm the reason why the query is blocklisted and remove the query from the blocklist after resolving the problem.
2.2.5 問(wèn)題解決,將作業(yè)移出黑名單
postgres=# select gs_remove_blocklist(2307078791); gs_remove_blocklist--------------------- t(1 row)
點(diǎn)擊關(guān)注,第一時(shí)間了解華為云新鮮技術(shù)~
標(biāo)簽:
搶先讀
- 成都個(gè)人信用卡停息掛賬怎么辦理?信用卡停息掛賬可以停多久?
- 2023年06月07日[國(guó)企改革]漲停板金字塔-當(dāng)前快看
- 天天快報(bào)!每體:巴薩計(jì)劃向梅西送上正式報(bào)價(jià),但球隊(duì)無(wú)法保證球員能被注冊(cè)
- 環(huán)球熱頭條丨博敏電子:截至本公告披露日 公司及其控股子公司對(duì)外擔(dān)??傤~為約26.88億元
- 焦點(diǎn)速遞!世界球精選!《GTAOL》6月13日更新:R星發(fā)布圣安地列斯傭兵首支預(yù)告
- 億利潔能資金懸疑:手握43億現(xiàn)金卻致7億票據(jù)逾期?-環(huán)球簡(jiǎn)訊
- 實(shí)時(shí):十年暖心相伴 北京鏈家200余家門(mén)店化身“高考服務(wù)站”
- GaussDB(DWS)查詢過(guò)濾器原理與應(yīng)用 每日熱文
- 天天快資訊:港交所:未來(lái)內(nèi)地投資者或可經(jīng)“港股通”買(mǎi)賣(mài)人民幣柜臺(tái)證券
- 市盈率是什么?怎么理解?
- 崇川社會(huì)工作領(lǐng)軍人才培訓(xùn)班開(kāi)班 幫助提升社區(qū)治理能力 天天速讀
- 信用卡停息掛賬還清后還能用嗎?停息掛賬的兩大危害你知道嗎?
- 萬(wàn)華化學(xué)等四川投資設(shè)立新能源材料科技公司|環(huán)球新資訊
- 【環(huán)球報(bào)資訊】博濟(jì)醫(yī)藥創(chuàng)業(yè)板再融資審核狀態(tài)更新為“已問(wèn)詢”
- 上海各銀行停息掛賬方式有哪些?信用卡逾期有什么影響?
- 人進(jìn)監(jiān)獄信用卡可以辦停息掛賬么?信用卡分期還款的流程介紹
- 停息掛賬去銀行好辦下來(lái)嗎?停息掛賬好申請(qǐng)嗎?
- 曬糧致科三考生掛科?交警:糧食覆蓋標(biāo)識(shí)線可能導(dǎo)致機(jī)器識(shí)別有誤_即時(shí)焦點(diǎn)
- 接受調(diào)查近11個(gè)月 河南銀保監(jiān)局原一級(jí)巡視員李煥亭被“雙開(kāi)”
- 粗心考生考前丟失身份證 考點(diǎn)執(zhí)勤民警1分鐘幫其出證入場(chǎng)
- 世界訊息:中概指數(shù)反彈并漲超1%,秦淮數(shù)據(jù)漲15%領(lǐng)跑其他成分股
- 7日年化收益率?7日年化收益率怎么算每天收益?
- 網(wǎng)貸停息掛賬上征信嗎?信用卡協(xié)商停息掛賬分期會(huì)影響征信嗎?
- 6月7日國(guó)內(nèi)鋅精礦市場(chǎng)價(jià)格匯總_焦點(diǎn)訊息
- 2023上海寶山區(qū)社區(qū)工作者招聘考試方法和內(nèi)容
- 聚焦“農(nóng)資+服務(wù)” 中國(guó)農(nóng)業(yè)農(nóng)村服務(wù)業(yè)聯(lián)盟對(duì)接活動(dòng)在山東桓臺(tái)舉辦
- 強(qiáng)制猥褻侮辱罪會(huì)判多少年
- 圖片報(bào):拜仁對(duì)克勒舍感興趣,但他現(xiàn)在不打算離開(kāi)法蘭克福 世界今熱點(diǎn)
- 停息掛賬證明怎么弄?停息掛賬自己怎么去申請(qǐng)?
- 環(huán)球信息:光大證券:鉀肥大合同價(jià)格的確定有望為國(guó)內(nèi)鉀肥價(jià)格提供底部支撐
- 天天亮點(diǎn)!在網(wǎng)絡(luò)賭博多久會(huì)判刑?
- 6月7日國(guó)內(nèi)苯酐產(chǎn)業(yè)鏈部分價(jià)格下滑 快看
- 環(huán)球微頭條丨華測(cè)檢測(cè)董秘回復(fù):公司的經(jīng)營(yíng)情況良好,一季度營(yíng)業(yè)收入和歸母凈利潤(rùn)均實(shí)現(xiàn)穩(wěn)定增長(zhǎng)
- 大行存款利率明日開(kāi)始下調(diào) 有銀行三年期定存調(diào)降15個(gè)基點(diǎn) 釋放什么信號(hào) 獨(dú)家焦點(diǎn)
- 金融機(jī)構(gòu)全力支持春耕、夏收 涉農(nóng)貸款增長(zhǎng)創(chuàng)新高
- 借唄怎么開(kāi)通?申請(qǐng)借唄需要什么條件?
- [大行評(píng)級(jí)]國(guó)信證券:給予金山軟件(03888.HK)“買(mǎi)入”評(píng)級(jí) 目標(biāo)價(jià)37.00至39.30港元
- 茶葉的分銷渠道_茶葉銷售渠道有哪些
- 環(huán)球快看點(diǎn)丨金地集團(tuán)董秘回復(fù): 一方面是土地儲(chǔ)備面積數(shù)據(jù),另一方面是合并報(bào)表的存貨科目,兩者并不直接對(duì)應(yīng),
- 美股鋰電公司中比新能源研發(fā)鈉離子電池,雙輪驅(qū)動(dòng)業(yè)績(jī)?cè)鲩L(zhǎng) 環(huán)球速看
- 【環(huán)球時(shí)快訊】洪都拉斯總統(tǒng)將訪華 中國(guó)外交部介紹此訪安排及期待
- 護(hù)航高考 餓了么在京開(kāi)展急送服務(wù) 天天頭條
- 今亮點(diǎn)!禪游科技(02660.HK)跌超10%,截至發(fā)稿,跌10.23%,報(bào)3.86港元,成交額1424.41萬(wàn)港元
- 區(qū)間放量平6.7倍什么意思 區(qū)間放量
- 青年志愿者“愛(ài)心助考”|短訊
- 世界關(guān)注:日播時(shí)尚(603196)6月7日14點(diǎn)41分觸及漲停板
- 當(dāng)前信息:深交所:騰信創(chuàng)新終止上市 6月15日起進(jìn)入退市整理期
- 【世界時(shí)快訊】我國(guó)連續(xù)第7個(gè)月增加黃金儲(chǔ)備 機(jī)構(gòu)預(yù)判兩年內(nèi)金價(jià)有望達(dá)2600美元/盎司
- 【天天聚看點(diǎn)】廣西壯族小伙的軍旅夢(mèng):從籃球冠軍到“武警精英”
- 東方電氣國(guó)內(nèi)單機(jī)容量最大沖擊式水電機(jī)組完成國(guó)產(chǎn)化改造|全球快播
- 世界觀焦點(diǎn):氧化鋁6月19日期貨掛牌交易 后市鋁價(jià)走向如何?
- 23安徽債61今日發(fā)布發(fā)行公告
- 天天觀速訊丨中華文明為何能延綿5000年未出現(xiàn)中斷?快到“國(guó)家書(shū)房”一探究竟
- 【全球速看料】東風(fēng)S3平臺(tái)首款新車下線!續(xù)航500km 11月量產(chǎn)
- 武漢數(shù)字經(jīng)濟(jì)總量占全市GDP超四成
- 環(huán)球熱點(diǎn)!岱勒新材:公司5月份處于滿產(chǎn)狀態(tài),產(chǎn)銷量已創(chuàng)歷史新高
- 廣西月也侗寨體驗(yàn)百家宴,近距離觀看歌舞表演,感受侗寨風(fēng)情-焦點(diǎn)快看
- cpk等于ppk cpk和ppk是什么意思 全球觀焦點(diǎn)
- 中國(guó)奇譚、寶可夢(mèng)、姆明……上海電視節(jié)線下放映排片來(lái)了,你最想看哪一部? 全球熱資訊
- 加稅立竿見(jiàn)影 新加坡5月外國(guó)人購(gòu)房量暴跌50%
- 什么是逆回購(gòu)?央行逆回購(gòu)是什么意思?_全球資訊
- 長(zhǎng)安汽車回應(yīng)網(wǎng)傳克扣10%貨款:不實(shí),已報(bào)案 全球最資訊
- 全球視訊!岱勒新材:公司4、5月份處于滿產(chǎn)狀態(tài) 5月份銷售額已創(chuàng)歷史新高 6月份會(huì)繼續(xù)提升
- 百度文心一言-Turbo高性能模式開(kāi)放邀測(cè) 世界實(shí)時(shí)
- kdj是什么意思?kdj三個(gè)參數(shù)的含義?
- 廣西某不銹鋼廠7月下旬起全線停產(chǎn)25天
- 產(chǎn)品質(zhì)量管理系統(tǒng)
- 信濠光電:公司一直致力于與消費(fèi)電子行業(yè)的主流品牌廠商保持密切合作
- 南京一大學(xué)生宿舍內(nèi)被害,疑似被人用刀捅傷身亡,嫌疑人已被控制 當(dāng)前速訊
- 中石油北京項(xiàng)目管理公司:胡繼勇被免職并接受紀(jì)委核查
- 天天熱頭條丨塔克拉瑪干沙漠腹地最大集中式光伏電站正式并網(wǎng)發(fā)電
- Moldex3D模流分析之充填保壓標(biāo)簽
- 最新!榮昌生物獲香港聯(lián)交所批準(zhǔn)從股票代碼中移除“B” 全球要聞
- 中國(guó)芯片穩(wěn)步推進(jìn),美國(guó)芯片行業(yè)已現(xiàn)頹勢(shì),韓荷認(rèn)清了現(xiàn)實(shí)_短訊
- 世界快報(bào):農(nóng)業(yè)農(nóng)村部、體育總局:將舉辦全國(guó)“村BA”
- 陽(yáng)江十里銀灘旅游攻略路線圖(陽(yáng)江十里銀灘旅游攻略)
- 每日訊息!荷蘭警方在澤蘭省截獲多批可卡因
- 烏克蘭卡霍夫卡水電站大壩遭破壞,外交部:嚴(yán)重關(guān)切
- 5月外儲(chǔ)仍超3萬(wàn)億美元、央行連續(xù)七個(gè)月增持黃金 釋放出什么信號(hào)?
- 當(dāng)前快訊:銨根離子是金屬離子嗎(銨根離子)
- 當(dāng)前視訊!鐵路網(wǎng)絡(luò)論壇網(wǎng)(鐵路在線論壇)
- 今日快訊:一箭26星!力箭一號(hào)遙二運(yùn)載火箭成功發(fā)射
- 剛剛,外匯局公布關(guān)鍵數(shù)據(jù)|世界看點(diǎn)
- 爵跡小說(shuō)一共有幾部?。ň糅E小說(shuō)一共有幾部)
- 微動(dòng)態(tài)丨精倫電子(600355)6月7日主力資金凈賣(mài)出221.17萬(wàn)元
- 中國(guó)東航:8月旅客周轉(zhuǎn)量同比上升62.14%|環(huán)球即時(shí)
- 【世界報(bào)資訊】寡助之至的下一句_寡助之至的之翻譯
- 給老師同學(xué)的祝福語(yǔ)_老師要求同學(xué)們明確目的和態(tài)度修改病句
- 四邊形有哪幾種它們各有什么特征_四邊形有哪幾種
- Lunaz展示其電動(dòng)阿斯頓馬丁DB6EV
- 世界新動(dòng)態(tài):獸不足到此人何取而自貽患耶_獸不足道,此人何取而自貽患耶翻譯
- 天天時(shí)訊:亞克力和有機(jī)玻璃哪個(gè)實(shí)用(亞克力和有機(jī)玻璃的區(qū)別)
- 重磅!福建省口岸轉(zhuǎn)關(guān)貨物直通模式將在莆田國(guó)際陸港開(kāi)展試點(diǎn)
- 為什么不建議對(duì)調(diào)輪胎(汽車前后輪胎多久調(diào)換一次?) 世界快訊
- 大學(xué)校長(zhǎng)屬于什么級(jí)別干部(寶馬z4屬于什么級(jí)別?)
- 4個(gè)工作日,北京大興發(fā)出首張“一業(yè)一證”行業(yè)綜合許可憑證
- 簽約投資額達(dá)44.5億元!河北10個(gè)氫能產(chǎn)業(yè)項(xiàng)目在佛山現(xiàn)場(chǎng)簽約
- 【環(huán)球時(shí)快訊】刺客信條2兄弟會(huì)迅雷(刺客信條2兄弟會(huì))
- 斷章卞之琳賞析簡(jiǎn)短_斷章卞之琳賞析|天天通訊
- 河北:推廣招標(biāo)投標(biāo)“雙盲”評(píng)審 全面推行評(píng)標(biāo)專家“盲抽”