一区二区三区成人_色婷婷av一区二区三区软件_国产精品福利av_亚洲五码中文字幕_色伊人久久综合中文字幕_欧美妇女性影城_亚洲一二三区在线观看_91在线视频网址_国产九色精品成人porny_国产一区二区电影_亚洲夂夂婷婷色拍ww47_日韩和欧美一区二区_国产欧美va欧美不卡在线_欧美电影免费观看完整版_日本不卡一区二区_韩国欧美一区二区

當前觀察:GaussDB(DWS)查詢過濾器原理與應(yīng)用

  • 博客園
  • 2023-06-07 21:28:58
摘要:GaussDB(DWS)查詢過濾器(黑名單)提供查詢過濾功能,支持自動隔離反復(fù)被終止的查詢,防止爛SQL再次執(zhí)行。

本文分享自華為云社區(qū)《GaussDB(DWS)查詢過濾器原理與應(yīng)用》,作者:門前一棵葡萄樹 。

一、概述

GaussDB(DWS)查詢過濾器(黑名單)提供查詢過濾功能,支持自動隔離反復(fù)被終止的查詢,防止爛SQL再次執(zhí)行。

主要應(yīng)用場景包含以下兩種:


(相關(guān)資料圖)

1. 異常熔斷機制

配置異常規(guī)則后,查詢觸發(fā)異常規(guī)則后,異常信息將被記錄在dbms_om.gs_blocklist_query系統(tǒng)表中。同一個查詢觸發(fā)異常規(guī)則次數(shù)超限(query_exception_count_limit)后,查詢自動加入黑名單,黑名單信息同樣保存在dbms_om.gs_blocklist_query系統(tǒng)表中。加入黑名單后,該查詢將被隔離,拒絕執(zhí)行。

2. 緊急攔截

作業(yè)引發(fā)CORE、hang或性能大幅下降等問題時,需要緊急規(guī)避時,可以將作業(yè)加入黑名單進行過濾。

原理介紹

查詢過濾器使用作業(yè)Unique SQL ID保存和識別作業(yè)黑名單和異常信息,在SQL中常數(shù)值發(fā)生變化時作業(yè)Unique SQL ID不會隨之發(fā)生變化。Unique SQL ID是遍歷查詢解析樹計算出來的一個整數(shù)值,用于標識一類SQL。通常對于DML語句,在計算Unique SQL ID的過程中會忽略常量值。但對于DDL、DCL以及設(shè)置參數(shù)等語句,常量值不會忽略。例如,以下兩個查詢:

select * from t1 where id = 1;select * from t1 where id = 2;

這兩條SQL除過濾條件中的常量不同外,其他全部相同,由此生成的解析樹拓撲完全相同,因此Unique SQL ID相同。Unique SQL ID的計算只會忽略常數(shù)值,而不會忽略其他差異,SQL語句“select * from t2 where id = 1;”與上述兩個SQL的Unique SQL ID就不相同。

將作業(yè)加入黑名單主要有以下兩種方式:

  • 在GUC參數(shù)query_exception_count_limit≥0情況下,作業(yè)觸發(fā)異常次數(shù)超過該閾值后自動將作業(yè)加入黑名單;
  • 調(diào)用內(nèi)置函數(shù)gs_append_blocklist(unique_sql_id int8)將作業(yè)加入黑名單。

作業(yè)執(zhí)行前判斷作業(yè)是否在黑名單中,如果作業(yè)在黑名單中,拒絕作業(yè)執(zhí)行,直接報錯退出。

作業(yè)被拒絕執(zhí)行后,對作業(yè)加入黑名單原因進行分析,問題解決后調(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è)就會被加入黑名單。

2. 配置異常規(guī)則

創(chuàng)建CPU平均使用率異常規(guī)則cpu_percent_except,作業(yè)運行時間超過2000秒且CPU使用率達到30%時觸發(fā)異常退出:

CREATE EXCEPT RULE cpu_percent_except WITH(ELAPSEDTIME=2000, CPUAVGPERCENT=30);

異常規(guī)則還支持BLOCKTIME、ALLCPUTIME、SPILLSIZE等異常的識別處理,具體可參考:異常規(guī)則簡介與演變。

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個異常規(guī)則集,每個異常規(guī)則集間獨立生效,互不影響。

4. 創(chuàng)建業(yè)務(wù)用戶usr1,關(guān)聯(lián)資源池respool1:

CREATE USER usr1 RESOURCE POOL "respool1" PASSWORD "XXXXXX";

5. 用戶usr1運行作業(yè),作業(yè)運行時間超過2000秒且CPU使用率達到30%時觸發(fā)“cpu_percent_except”異常規(guī)則,作業(yè)觸發(fā)異常規(guī)則后資源管理對作業(yè)進行以下處理:

  • 將作業(yè)異常信息保存至系統(tǒng)表GS_BLOCKLIST_QUERY中;
  • 如果作業(yè)觸發(fā)異常熔斷,將系統(tǒng)表GS_BLOCKLIST_QUERY中作業(yè)黑名單標志置為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è)觸發(fā)異常熔斷,GaussDB(DWS)的異常熔斷機制禁止該作業(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所運行ID為4066836196的SQL后,將ID為4066836196的SQL從黑名單移除。

確認SQL異常原因,如果異常規(guī)則配置不合理,修改異常規(guī)則;如果異常規(guī)則合理,對SQL進行優(yōu)化后重新運行。確認問題解決后將SQL移除黑名單。

select gs_remove_blocklist(4066836196); gs_remove_blocklist--------------------- t(1 row)

2.2 緊急攔截示例

查詢過濾器使用作業(yè)Unique SQL ID識別和保存黑名單信息,為有效運用查詢過濾器緊急攔截功能,建議TopSQL開啟,在作業(yè)引發(fā)CORE、報錯、性能下降等問題時可以快速獲取作業(yè)Unique SQL ID。

2.2.1 獲取作業(yè)Unique SQL ID

獲取作業(yè)Unique SQL ID的幾種方法:

1. 作業(yè)引發(fā)報錯/性能下降

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對應(yīng)的變量參數(shù)值。

3. 作業(yè)引發(fā)DN實例CORE

作業(yè)引發(fā)DN實例CORE時,CN側(cè)體現(xiàn)為作業(yè)報錯,Unique SQL ID獲取方式可以參考作業(yè)報錯時Unique SQL ID獲取方式。

4. EXPLAIN VERBOSE獲取Unique SQL ID(通用方法,但是僅821及以上版本支持)

EXPLAIN VERBOSE不會實際執(zhí)行SQL,因此一般不會導(dǎo)致問題發(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)表確認黑名單加入是否成功:

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 問題解決,將作業(yè)移出黑名單

postgres=# select gs_remove_blocklist(2307078791); gs_remove_blocklist--------------------- t(1 row)

點擊關(guān)注,第一時間了解華為云新鮮技術(shù)~

關(guān)鍵詞:

分享到:
?
  • 至少輸入5個字符
  • 表情

熱門資訊

一区二区三区成人_色婷婷av一区二区三区软件_国产精品福利av_亚洲五码中文字幕_色伊人久久综合中文字幕_欧美妇女性影城_亚洲一二三区在线观看_91在线视频网址_国产九色精品成人porny_国产一区二区电影_亚洲夂夂婷婷色拍ww47_日韩和欧美一区二区_国产欧美va欧美不卡在线_欧美电影免费观看完整版_日本不卡一区二区_韩国欧美一区二区
高清国产在线一区| 东方aⅴ免费观看久久av| 亚洲欧美综合另类在线卡通| 久久五月婷婷丁香社区| 日韩亚洲欧美综合| 精品国产亚洲在线| 国产亚洲一区二区三区四区| 欧美国产综合一区二区| 亚洲婷婷综合久久一本伊一区| 中文乱码免费一区二区| 亚洲视频在线一区观看| 亚洲一区在线免费观看| 免费成人在线观看| 国产成人精品亚洲午夜麻豆| 91原创在线视频| 久久av一区二区三区亚洲| 亚洲高清乱码| 91精品国产综合久久久久久| 99re成人精品视频| 国产精品区一区二区三含羞草| 蜜桃视频日韩| 欧美日韩一区二区三区在线看| 欧美大片一区二区| 国产精品国产三级国产| 日韩高清不卡在线| 99国产精品久久久| 亚洲欧洲精品在线| 精品少妇一区二区三区视频免付费| 国产精品视频免费看| 亚洲成人动漫av| 成人美女视频在线观看| 九九久久99| 欧美日韩免费视频| 国产精品久久久久婷婷| 日韩av中文在线观看| 91麻豆国产自产在线观看| 亚洲精品8mav| 久久老女人爱爱| 日日欢夜夜爽一区| 99精彩视频在线观看免费| 一本到不卡免费一区二区| 久久久久国产一区二区三区四区| 亚洲国产sm捆绑调教视频| 成人综合婷婷国产精品久久免费| 欧美国产综合视频| 日韩一区二区免费电影| 一区二区三区在线视频观看58| 国内外精品视频| 免费国产在线精品一区二区三区| 欧美精品三级在线观看| 亚洲伊人伊色伊影伊综合网| 99久久综合99久久综合网站| 最新国产精品久久| 国产精品视频一二| 高清国产一区二区| 亚洲一区二区三区涩| 亚洲国产精品ⅴa在线观看| 经典一区二区三区| 视频一区视频二区视频三区高| 欧美精品一区二区三区四区| 麻豆传媒一区二区三区| 欧美美乳视频网站在线观看| 亚洲精品一区二区三区香蕉| 免费国产亚洲视频| 欧美精品欧美精品系列c| 欧美成人a∨高清免费观看| 一本一道波多野结衣一区二区| 欧美精品一区二区三区视频| 日韩高清中文字幕一区| 国产精品伊人日日| 久久综合九色综合97_久久久| 免费成人美女在线观看| 色综合666| 国产精品动漫网站| 99在线精品一区二区三区| 欧美视频完全免费看| 亚洲成人一区二区| 欧美亚州在线观看| 国产精品麻豆视频| 91丨porny丨国产入口| 777奇米成人网| 久久国产福利国产秒拍| 色综合久久综合网| 午夜伦欧美伦电影理论片| 欧美久久久久久久| ●精品国产综合乱码久久久久| 91毛片在线观看| 精品国产99国产精品| 国产福利91精品一区| 欧美男女性生活在线直播观看| 视频一区视频二区中文字幕| 香蕉久久免费影视| 亚洲图片一区二区| 亚洲午夜激情| 视频一区中文字幕| 色哟哟欧美精品| 日韩成人av影视| 色噜噜夜夜夜综合网| 人禽交欧美网站| 欧洲一区在线电影| 久久成人麻豆午夜电影| 欧美裸体bbwbbwbbw| 国产在线播放一区三区四| 91精品中文字幕一区二区三区| 国产一本一道久久香蕉| 日韩欧美国产综合一区| aaa亚洲精品| 久久影音资源网| 国产精品12| 夜夜爽夜夜爽精品视频| 中文字幕中文字幕99| 久久精品久久综合| av亚洲产国偷v产偷v自拍| 欧美tickling网站挠脚心| 99re成人在线| 中文字幕一区不卡| 蜜桃狠狠色伊人亚洲综合网站| 专区另类欧美日韩| 日韩电影大全在线观看| 日韩成人精品视频| 91精品在线免费| 91av一区二区三区| 亚洲卡通欧美制服中文| 视频一区国产精品| 久久99精品久久久久久国产越南 | 亚洲成人自拍| 奇米精品一区二区三区四区| 7777精品伊人久久久大香线蕉| 成人av网站在线观看免费| 国产精品成人网| 色婷婷精品大在线视频| 成人午夜激情片| 亚洲人成在线观看一区二区| 亚洲美女网站18| 粉嫩欧美一区二区三区高清影视 | 在线视频国内一区二区| 成人网页在线观看| **性色生活片久久毛片| 中文字幕av日韩精品| 国产成人在线免费观看| 中文一区二区在线观看| 亚洲综合av一区| 国产成人精品一区二| 中文字幕亚洲成人| 欧美日韩国产一级| 国产伦精品一区二区三区高清| 亚洲成av人片| 精品国产制服丝袜高跟| 日本亚洲最大的色成网站www| 欧美性生活大片视频| 成人动漫在线观看视频| 日韩av中文字幕一区二区| 久久久天堂av| 欧洲一区二区三区在线| 福利视频一区二区三区| 激情综合网激情| 亚洲欧美在线视频| 欧美一卡二卡在线观看| 日本午夜精品电影| 成人免费黄色大片| 午夜天堂影视香蕉久久| 久久精品夜夜夜夜久久| 在线观看免费视频综合| 国产伦精品一区二区三区视频孕妇 | 国产精品美女久久久久av福利| 日本成人在线一区| 国产精品免费看片| 91精品国产福利| 色婷婷精品国产一区二区三区| 成人av网站免费观看| 日韩成人一区二区| 中文字幕亚洲综合久久菠萝蜜| 精品视频一区三区九区| 麻豆亚洲一区| 91浏览器入口在线观看| 激情成人综合网| 亚洲成人资源在线| 中文字幕一区二区三| 欧美电影免费观看高清完整版| 亚洲综合av一区| 久久婷婷人人澡人人喊人人爽| 国产精品18久久久久久vr| 亚洲国产精品综合小说图片区| 国产喂奶挤奶一区二区三区| 欧美一二三区在线| 欧美视频在线不卡| 一本久道中文字幕精品亚洲嫩| 国产综合动作在线观看| 99精品国产99久久久久久白柏| 久久精品国产在热久久| 丝袜诱惑制服诱惑色一区在线观看| 国产精品久久久久影院色老大| 欧美tickling网站挠脚心| 欧美日韩成人在线一区| 在线国产伦理一区| 亚洲国产精品综合| 欧美三日本三级少妇三99| 精品在线不卡| 成人综合电影| 国产三级三级三级精品8ⅰ区|