国产一区二区美女诱惑_国产精品免费播放_91精品国产综合久久香蕉麻豆 _久久精品30_久久综合88_国产精品亚洲成人_黑人极品videos精品欧美裸_亚洲色图欧美激情

原創(chuàng)生活

國內(nèi) 商業(yè) 滾動

基金 金融 股票

期貨金融

科技 行業(yè) 房產(chǎn)

銀行 公司 消費

生活滾動

保險 海外 觀察

財經(jīng) 生活 期貨

當前位置:滾動 >

GaussDB(DWS)查詢過濾器原理與應用_環(huán)球快消息

文章來源:博客園  發(fā)布時間: 2023-06-07 16:34:57  責任編輯:cfenews.com
+|-
摘要:GaussDB(DWS)查詢過濾器(黑名單)提供查詢過濾功能,支持自動隔離反復被終止的查詢,防止爛SQL再次執(zhí)行。

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


【資料圖】

一、概述

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

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

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ù)等語句,常量值不會忽略。例如,以下兩個查詢:

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è)移除黑名單。

二、應用示例

2.1 異常熔斷示例

1. 設置異常熔斷閾值。假設設置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關聯(lián)異常規(guī)則cpu_percent_except

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

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

4. 創(chuàng)建業(yè)務用戶usr1,關聯(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對應的變量參數(shù)值。

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

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

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

EXPLAIN VERBOSE不會實際執(zhí)行SQL,因此一般不會導致問題發(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)

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

關鍵詞:

專題首頁|財金網(wǎng)首頁

投資
探索

精彩
互動

獨家
觀察

京ICP備2021034106號-38   營業(yè)執(zhí)照公示信息  聯(lián)系我們:55 16 53 8 @qq.com 關于我們 財金網(wǎng)  版權所有  cfenews.com
亚洲高清免费| 精品亚洲一区二区| 欧美日韩一区二区三区在线| 欧美一级xxx| 五月天婷婷综合社区| 中文字幕在线一二| 182tv在线播放| 一本一道久久a久久| 66久久国产| 国产乱码精品一区二区三区五月婷| 久久你懂得1024| 欧美午夜精品在线| 亚洲欧美日韩综合| 中文字幕中文字幕在线十八区| 国产aa精品| 国模 一区 二区 三区| 另类小说综合欧美亚洲| 国产精品丝袜91| 欧美一区二区人人喊爽| 国产精品四虎| 日韩视频在线直播| 国产一级一区二区| 亚洲欧洲av在线| 亚洲精品美女久久久| 超碰在线观看免费| 免费国产自久久久久三四区久久| 国产一区二区你懂的| 成人欧美一区二区三区黑人麻豆| 精品久久五月天| 精品国产99久久久久久| 国产图片一区| 久久国产视频网| 欧美午夜视频一区二区| 在线观看你懂| 精品国产三级| 日本女人一区二区三区| 天天操天天干天天综合网| 91在线网站| 国产精品中文| 日韩福利视频导航| 午夜久久久久久久久| 一级毛片国产| 99热这里有精品| 免费视频一区二区| 欧美在线观看一区| 久久bbxx| 伊人久久大香线蕉综合四虎小说 | 自拍偷拍亚洲综合| 亚洲加勒比久久88色综合| 国产黄色大片在线观看| 亚洲欧美亚洲| 亚洲精品免费在线| 中文字幕在线观看第一页| 亚洲性视频在线| 国产成人亚洲精品狼色在线| 欧美一区二区三区在| 国产伦理精品| 在线综合欧美| 欧美性猛交xxxxx水多| 欧美性videos| 欧美激情 亚洲a∨综合| 亚洲综合色在线| 蜜桃视频在线免费| 欧美一站二站| 亚洲欧美日韩在线| 在线天堂视频| 成人精品视频| 一区二区三区四区国产精品| 免费在线黄色网址| 99精品在线观看| 亚洲国产视频网站| 狠狠v欧美ⅴ日韩v亚洲v大胸 | 禁久久精品乱码| 精品国产91久久久久久| 羞羞网站在线看| 久久激情一区| 日韩欧美精品在线视频| 欧美一区=区三区| 国产精品伊人色| 免费h片在线| 亚洲视频分类| 亚洲一区二区av电影| 亚洲性图自拍| 天堂va蜜桃一区二区三区漫画版| 欧美色手机在线观看| 蜜臀国产一区| 97国产精品videossex| 精东影业在线观看| 你懂的视频一区二区| 色婷婷亚洲婷婷| 视频一区在线免费看| 91视视频在线观看入口直接观看www | 欧美性极品xxxx娇小| 欧美一卡二卡| 国产伦精品一区二区三区视频青涩 | 秋霞伦理一区| 99亚偷拍自图区亚洲| 麻豆导航在线观看| 国产一区二区三区的电影| 亚洲国产美女久久久久| 免费欧美一区| 欧美在线观看18| 国产麻豆一区二区三区| 亚洲三级视频在线观看| 日韩123区| ww亚洲ww在线观看国产| 里番在线观看网站| 国产精品夜夜爽| 国产香蕉在线| 国产在线精品一区二区夜色| 免费男女羞羞的视频网站主页在线观看| 国产韩日影视精品| 欧美一区二区三区公司| 狠狠做六月爱婷婷综合aⅴ | 日韩在线免费| 亚洲另类在线一区| 成人在线视频播放| 亚洲欧美日韩一区二区三区在线观看| 久草中文在线观看| 99re热这里只有精品免费视频| 97电影在线| www.久久精品| 丁香花高清在线观看完整版| 国产日韩欧美一区二区三区综合| 羞羞的视频在线观看| 91亚洲国产成人精品一区二三 | 精品一区二区综合| 77777影视视频在线观看| 成人免费观看视频| 日本天码aⅴ片在线电影网站| 91色.com| 一级毛片久久久| 亚洲一区在线观看免费| 久久精品国产福利| 在线亚洲人成电影网站色www| 思热99re视热频这里只精品| 日韩一区二区精品在线观看| 婷婷久久国产对白刺激五月99| 亚洲精品中文字幕有码专区| 亚洲精品一级| 在线影视一区| www.av亚洲| 台湾成人免费视频| 在线观看中文字幕不卡| 久久电影院7| 一级特黄特色的免费大片| 日韩激情中文字幕| 1024国产在线| xxxxx日韩| 亚洲一二三四区不卡| 亚洲男男gay视频| 色狠狠一区二区三区| 国内精品伊人久久久久av影院| 一区二区三区四区蜜桃| а天堂8中文最新版在线官网| 欧美日韩专区| 色综合一个色综合| 78精品国产综合久久香蕉| www.欧美亚洲| 国产污视频在线播放| 高清日韩电视剧大全免费| 奇米影视888狠狠狠777不卡| 国产尤物久久久| 亚洲妇女屁股眼交7| 日本午夜精品| 久久久91精品国产一区二区三区| 精品粉嫩超白一线天av| 欧美videos另类精品| 国产一区二区在线观看免费| 91破解版在线看| 国产酒店精品激情| 天堂网在线观看国产精品| jizzjizz中国精品麻豆| 亚洲一区二区三区无吗| 在线看你懂得| 9久草视频在线视频精品| 欧美黑人疯狂性受xxxxx野外| 欧美在线视频日韩| 亚洲国产精品一区| 成人在线app| 婷婷开心激情综合| 亚洲色图网站| 欧美色视频免费| 亚洲精品乱码久久久久| 亚洲欧洲色图| 四虎精品在永久在线观看| 国产日韩欧美不卡| 亚洲v天堂v手机在线| 一区二区三区性视频| 亚洲欧美日韩在线播放| 我不卡伦不卡影院| 欧美激情午夜| 精品久久中文字幕久久av| 尤物在线精品| 僵尸再翻生在线观看| 精品成人佐山爱一区二区| 不卡的av网站| 精品国产乱码| 中文字幕伦理免费在线视频| 7777精品伊人久久久大香线蕉最新版|