亚洲综合视频在线_国产亚洲欧洲一区高清在线观看_欧美日韩成人综合_国产精品99久久久久久白浆小说_美女在线一区二区_欧美性xxxxx极品_国内偷自视频区视频综合_亚洲色图18p_亚洲视频一二三区_国产日韩欧美中文

GaussDB(DWS)查詢過濾器原理與應用

2023-06-07 23:01:54 來源:博客園

打印 放大 縮小
摘要:GaussDB(DWS)查詢過濾器(黑名單)提供查詢過濾功能,支持自動隔離反復被終止的查詢,防止爛SQL再次執行。

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

一、概述

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


(資料圖片僅供參考)

主要應用場景包含以下兩種:

1. 異常熔斷機制

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

2. 緊急攔截

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

原理介紹

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

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

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

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

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

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

作業被拒絕執行后,對作業加入黑名單原因進行分析,問題解決后調用內置函數gs_remove_blocklist(unique_sql_id int8)將作業移除黑名單。

二、應用示例

2.1 異常熔斷示例

1. 設置異常熔斷閾值。假設設置query_exception_count_limit=1,即只要作業觸發異常規則作業就會被加入黑名單。

2. 配置異常規則

創建CPU平均使用率異常規則cpu_percent_except,作業運行時間超過2000秒且CPU使用率達到30%時觸發異常退出:

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

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

3. 創建資源池respool1關聯異常規則cpu_percent_except

CREATE RESOURCE POOL respool1 WITH(except_rule="cpu_percent_except");

資源池支持最多關聯63個異常規則集,每個異常規則集間獨立生效,互不影響。

4. 創建業務用戶usr1,關聯資源池respool1:

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

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

  • 將作業異常信息保存至系統表GS_BLOCKLIST_QUERY中;
  • 如果作業觸發異常熔斷,將系統表GS_BLOCKLIST_QUERY中作業黑名單標志置為true;
  • 更新GS_BLOCKLIST_QUERY中作業黑名單信息。

6. 查詢作業黑名單和異常信息:

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再次運行作業觸發異常熔斷,GaussDB(DWS)的異常熔斷機制禁止該作業執行。

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. 優化用戶usr1所運行ID為4066836196的SQL后,將ID為4066836196的SQL從黑名單移除。

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

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

2.2 緊急攔截示例

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

2.2.1 獲取作業Unique SQL ID

獲取作業Unique SQL ID的幾種方法:

1. 作業引發報錯/性能下降

CN日志中獲取作業query_id,執行以下命令查詢作業Unique SQL ID。

select queryid,unique_sql_id,query from pgxc_wlm_session_info where queryid=query_id;

2. 作業引發CN示例CORE

解析CORE打印內存中保存的Unique SQL ID對應的變量參數值。

3. 作業引發DN實例CORE

作業引發DN實例CORE時,CN側體現為作業報錯,Unique SQL ID獲取方式可以參考作業報錯時Unique SQL ID獲取方式。

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

EXPLAIN VERBOSE不會實際執行SQL,因此一般不會導致問題發生,使用EXPLAIN VERBOSE XXX;可以打印得到作業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 將作業加入黑名單

獲取到作業Unique SQL ID后,調用內置函數gs_append_blocklist(unique_sql_id int8)將作業加入黑名單:

postgres=# select * from gs_append_blocklist(2307078791); gs_append_blocklist--------------------- t(1 row)

2.2.3 查詢黑名單信息

作業加入黑名單后,查詢系統表確認黑名單加入是否成功:

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 再次執行作業觸發緊急攔截

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

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

點擊關注,第一時間了解華為云新鮮技術~

關鍵詞:

責任編輯:ERM523

相關閱讀

亚洲综合视频在线_国产亚洲欧洲一区高清在线观看_欧美日韩成人综合_国产精品99久久久久久白浆小说_美女在线一区二区_欧美性xxxxx极品_国内偷自视频区视频综合_亚洲色图18p_亚洲视频一二三区_国产日韩欧美中文
国产精品99久久久久久有的能看| 欧美福利视频导航| 狠狠久久亚洲欧美| 色拍拍在线精品视频8848| 亚洲视频一区二区在线| 粉嫩一区二区三区性色av| 免费观看日韩电影| 宅男噜噜噜66一区二区66| 亚洲天堂精品在线观看| 91美女视频网站| 91麻豆精品国产91久久久更新时间| 天堂成人国产精品一区| 欧美精品精品一区| 日本一道高清亚洲日美韩| 欧美肥妇bbw| 日韩精品亚洲专区| 日韩欧美中文字幕公布| 国产黄色91视频| 国产三级精品视频| 色诱视频网站一区| 天使萌一区二区三区免费观看| 欧美日产在线观看| 国产精品自拍在线| 亚洲色图视频网站| 欧美蜜桃一区二区三区| 国产福利91精品一区二区三区| 国产精品免费看片| 成人av综合在线| 亚洲综合一区在线| 精品久久久久久久久久久久久久久久久 | 精品剧情v国产在线观看在线| 久久69国产一区二区蜜臀| 久久先锋资源网| 99re这里都是精品| 偷拍自拍另类欧美| 久久伊人蜜桃av一区二区| 91视频精品在这里| 九色综合狠狠综合久久| 日韩丝袜美女视频| 色综合一区二区| 国产成人免费视| 人人狠狠综合久久亚洲| 国产成人精品一区二区三区四区| 成人欧美一区二区三区在线播放| 欧美日韩亚洲另类| 97精品视频在线观看自产线路二| 亚洲最大成人网4388xx| 久久久国产一区二区三区四区小说 | 国产一区免费电影| 亚洲色图欧美偷拍| 久久婷婷成人综合色| 国产99精品国产| 日本成人在线电影网| 亚洲综合视频在线| 中文字幕色av一区二区三区| 日韩精品专区在线| 欧美喷潮久久久xxxxx| 色噜噜狠狠色综合中国| 成人av电影观看| 北条麻妃一区二区三区| 亚洲国产精品一区二区www在线| 一本色道久久加勒比精品| 国产精品中文字幕欧美| 精东粉嫩av免费一区二区三区| 蜜臀久久久久久久| 亚洲男人的天堂在线aⅴ视频| 国产精品国产精品国产专区不蜜| 久久精品人人做人人爽97| 久久嫩草精品久久久精品一| 色综合 综合色| 在线观看视频一区| 欧美日韩一二三| 日韩一区二区视频在线观看| 日韩精品中文字幕在线不卡尤物| 欧美sm美女调教| 国产亚洲欧美中文| 国产精品免费久久| 亚洲午夜成aⅴ人片| 中文字幕精品三区| 亚洲综合视频网| 亚洲视频在线一区二区| 亚洲一区二区不卡免费| 另类小说一区二区三区| 福利电影一区二区| 欧美自拍偷拍一区| 欧美一区日韩一区| 欧美精品1区2区| 国产精品免费视频网站| 五月天久久比比资源色| 国产伦精一区二区三区| 在线视频你懂得一区| 99国产精品久久久久久久久久久| 欧美日韩精品一区二区三区 | 亚洲色图在线看| 国产自产v一区二区三区c| 久久精品国产99国产精品| 91香蕉视频黄| 精品久久久三级丝袜| 一区二区三区四区不卡视频| 久久99精品久久久久| 91精品办公室少妇高潮对白| 久久网站最新地址| 图片区日韩欧美亚洲| 99久久99精品久久久久久| 精品成人一区二区三区四区| 国产欧美一区二区在线观看| 日本午夜一本久久久综合| 91麻豆免费在线观看| 久久精品夜夜夜夜久久| 免费三级欧美电影| 日韩av高清在线观看| 91丨九色丨尤物| 国产精品丝袜久久久久久app| 久草热8精品视频在线观看| 3atv在线一区二区三区| 午夜av区久久| 久久亚洲精品小早川怜子| 国产综合色在线视频区| 久久精品综合网| 91亚洲午夜精品久久久久久| 亚洲精品成人精品456| 欧美色区777第一页| 日韩1区2区3区| 精品国产免费人成在线观看| 风间由美一区二区三区在线观看 | 国产一区二区在线观看视频| 国产欧美一区二区三区在线看蜜臀| 国产白丝网站精品污在线入口| 国产精品入口麻豆原神| 91国偷自产一区二区使用方法| 图片区小说区区亚洲影院| 欧美成人国产一区二区| 波波电影院一区二区三区| 亚洲国产精品一区二区久久| 精品国产乱码久久久久久久久| 狠狠色丁香九九婷婷综合五月| 国产欧美一二三区| 欧美日韩国产美| 福利电影一区二区三区| 日韩高清在线一区| 1区2区3区欧美| 欧美电影免费观看高清完整版| 白白色 亚洲乱淫| 日韩高清不卡一区二区三区| 中文在线一区二区| 日韩一级片网址| 91激情五月电影| 成人丝袜18视频在线观看| 日本中文一区二区三区| 一区在线播放视频| 精品国产乱码久久久久久图片| 一本大道久久a久久综合| 国产美女在线精品| 麻豆国产精品官网| 图片区小说区国产精品视频| 亚洲欧洲无码一区二区三区| 久久精品亚洲乱码伦伦中文| 日韩精品影音先锋| 91精品国产综合久久蜜臀| 91成人免费在线| 成人动漫一区二区三区| 国产一区二区精品久久| 久久99精品视频| 国产一区在线观看麻豆| 老色鬼精品视频在线观看播放| 亚洲va欧美va天堂v国产综合| 一区二区三区四区在线免费观看| 国产精品欧美一区喷水| 国产精品私人影院| 亚洲国产精品激情在线观看| 国产拍揄自揄精品视频麻豆| 国产亚洲欧美日韩日本| 久久婷婷国产综合精品青草| 精品国产亚洲一区二区三区在线观看| 欧美疯狂性受xxxxx喷水图片| 欧美久久久影院| 日韩欧美三级在线| 日本一区二区三区电影| 国产精品久久久久久妇女6080| 国产精品福利电影一区二区三区四区| 国产精品久久久久久久久免费桃花 | 色综合久久88色综合天天| 欧美性生活影院| 欧美高清一级片在线| 欧美大片在线观看一区二区| 久久综合九色综合欧美就去吻| 欧美激情在线一区二区三区| 国产日韩成人精品| 夜夜精品视频一区二区| 精品一区二区在线观看| 成人av免费观看| 日韩亚洲欧美成人一区| 国产三级久久久| 午夜精品一区在线观看| 国产精品一色哟哟哟| 日本高清免费不卡视频| 精品久久人人做人人爽| 亚洲一区二区三区小说| 国产suv精品一区二区6| 91精品国产品国语在线不卡|