校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > PostgreSQL 如何查找需要收集的vacuum 表信息

PostgreSQL 如何查找需要收集的vacuum 表信息

熱門標簽:江西穩定外呼系統供應商 無錫梁溪公司怎樣申請400電話 北京智能外呼系統供應商家 孝感銷售電銷機器人廠家 高德地圖標注電話怎么沒了 智能電銷機器人教育 電話機器人錄音師薪資 中國地圖標注省份用什么符號 奧維地圖標注字體大小修改

前言

通常,在PostgreSQL中,由于經常需要對表進行 UPDATE 和 DELETE,因此表會產生碎片空間。

在 PostgreSQL中,使用VACUUM 僅僅對需要執行 VACUUM 表將已刪除的空間標識為未使用,以便以后重用這些空間,但是不能立即將占用的空間返還給操作系統,因此需要使用 VACUUM FULL,才可以釋放空間,并立即將空間返還給操作系統。

實現腳本

記錄收集表創建

CREATE TABLE IF NOT EXISTS tab_vacuum_record
(sqltext text);

收集需要VACUUM 表函數

CREATE OR REPLACE FUNCTION f_vacuum_tables()
RETURNS void AS
$FUNCTION$
 DECLARE
 v_tablename text;
 v_dead_cond bigint;
 v_sql    text;
 cur_tablename REFCURSOR;
 v_vacuum_record text;
 BEGIN
 v_vacuum_record := 'tab_vacuum_record';
 OPEN cur_tablename FOR SELECT tablename FROM pg_tables WHERE tablename !~ '^pg|^sql';
 LOOP
  FETCH cur_tablename INTO v_tablename;
   SELECT n_dead_tup INTO v_dead_cond FROM pg_stat_user_tables WHERE relname = v_tablename;
     IF v_dead_cond > 0 THEN
      v_sql := 'INSERT INTO ' || v_vacuum_record || ' VALUES(' || chr(39) ||'VACUUM FULL ' || v_tablename ||';'|| chr(39) ||')';
    EXECUTE v_sql;
     END IF;
   EXIT WHEN NOT FOUND;
 END LOOP;
 CLOSE cur_tablename;
 END;
$FUNCTION$
LANGUAGE PLPGSQL;

SHELL腳本

#!/bin/bash
#獲取環境變量
CURRDIR=$(cd "$(dirname $0)";pwd)
TOPDIR=$(cd $CURRDIR/..;pwd)
CONFIG=$TOPDIR/conf/host.ini
CT_FILE=${TOPDIR}/sql/CREATE_VACCUM_TABLE_RECORD.sql
CT_FUNCTION=${TOPDIR}/sql/CHECK_NEEDS_VACUUM_TABLE_FUNCTION.sql
source $CONFIG
CONNINFO="psql -U $USER -d $DBNAME -h $HOSTADDR -p $PORT"
function check_status()
{
    echo "檢查數據庫服務器狀態是否正常 !"
    stat=`$CONNINFO -Aqt -c 'SELECT 1'`
    if [ "${stat}" == "1" ];then
        echo "服務器連接正常"
    else
        echo "服務器連接異常,退出"
        exit -1;
    fi
}
function create_table()
{
    echo "創建收集需要vacuum的表"
    $CONNINFO -f $CT_FILE
}
function create_function()
{
    echo "創建收集需要 vacuum 表的函數"
    $CONNINFO -f $CT_FUNCTION
}
check_status
create_table
create_function

執行方式

postgres=# SELECT * FROM f_vacuum_tables();
 f_vacuum_tables 
-----------------
 
(1 row)
--創建測試表
postgres=# CREATE TABLE tab_test(id int);
--插入數據
postgres=# INSERT INTO tab_test SELECT id FROM generate_series(1,100000) as id;
INSERT 0 100000
--刪除數據
postgres=# DELETE FROM tab_Test WHERE id = 10000;
DELETE 10002
postgres=# SELECT * FROM tab_vacuum_record ;
    sqltext    
-----------------------
 VACUUM FULL tab_test;
(1 row)

該腳本也可以自己根據需要進行修改,詳細見github

補充:PostgreSQL中 Vacuum 略談

VACUUM doc

路由清理

PostgreSQL 需要定期維護清理,一般都是由守護進程自動清理的,我們只是需要參數調優,也可以執行腳本定時去清理回收。

Vacuumming Basics

PG不得不對每張表進行 Vacuum 命令,原因如下:

1、為了回收和再利用通過更新或者刪除行所占用的磁盤空間

2、為了更新被PG查詢計劃所使用的數據分析

3、為了更新只讀索引掃描的可見的集合

4、避免由于事務ID或者混合事務ID丟失歷史數據

由于這些原因,在進行頻繁的 VACUUM 操作時進行規定:

標準 VACUUM

進行回收時,生產環境不影響數據庫庫的正常使用(SELECT、INSERT、UPDATE、DELETE),并行使用,清理時不允許對表結構進行修改(ALTER TABLE)推薦使用該方案

VACUUM FULL

a、可以回收大量空間,但是比標準回收執行慢

b、運行時需要鎖表

VACUUM 運行會導致讀寫性能比較差,所以需要調整一些參數降低影響

temp_file_limit = -1 #默認-1表示不限制每個進程可使用的最大臨時文件限制,單位kb
#max_files_per_process = 1000 #每個子進程允許同時打開文件的最大數量

在執行 VACUUM 和 ANYLYZE 期間,系統會維護一個用于估算各種I/O操作所消耗的內部計數器,當該值達到vacuum_cost_limit的值時,該進程會休眠 vacuum_cost_delay 指定的時間,并重置計數器的值,繼續運行 VACUM 或者 ANYLYZE 操作

vacuum_cost_limit = 200 
vacuum_cost_delay = 0 # 單位微秒,默認為 0 沒有開啟

該參數 vacuum_cost_delay 主要用于并發時降低I/O的影響,推薦為10

vacuum_cost_page_hit = 1 # 代表從緩存池查找共享的hash table并掃描 該`頁`的內容
             #的估計值
vacuum_cost_page_miss = 10   # 0-10000 credits
vacuum_cost_page_dirty = 20

NOTE

當一張表中包含了大量數據時,同時進行刪除或者更新操作時,VACUUM 并不是最好的方案,

如果有該情況,則應該使用 VACUU FULL ,當執行 ALTER TABLE 時,會重新 COPY整

個表和重新構建索引,會進行執行鎖,臨時占用和原始表大小的磁盤空間,直到新數據COPY完成。

升級執行計劃

執行計劃通過自己或者 VACUUM調用命令 ANALYZE 收集統計,

創建 表達式索引 能夠提高查詢執行計劃

default_statistics_target = 100 #提高查詢的 析計劃

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostgreSQL對GROUP BY子句使用常量的特殊限制詳解
  • PostgreSQL中的VACUUM命令用法說明
  • PostgreSQL備份工具 pgBackRest使用詳解
  • postgresql數據合并,多條數據合并成1條的操作
  • postgresql數據添加兩個字段聯合唯一的操作
  • postgreSQL使用pgAdmin備份服務器數據的方法
  • Postgresql 查看SQL語句執行效率的操作

標簽:齊齊哈爾 臨滄 通化 阜陽 海北 荊州 那曲 泰州

巨人網絡通訊聲明:本文標題《PostgreSQL 如何查找需要收集的vacuum 表信息》,本文關鍵詞  PostgreSQL,如何,查找,需要,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL 如何查找需要收集的vacuum 表信息》相關的同類信息!
  • 本頁收集關于PostgreSQL 如何查找需要收集的vacuum 表信息的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    精品一区二区久久久| 免费看精品久久片| av一区二区久久| 2020日本不卡一区二区视频| 日本中文字幕一区二区视频| 欧美性猛交xxxx乱大交退制版| 91精品国产入口| 激情六月婷婷综合| 欧美精品一区二区不卡| 国产综合久久久久久鬼色 | 在线电影院国产精品| 香蕉久久一区二区不卡无毒影院| 91亚洲精品久久久蜜桃网站 | 中文字幕一区二区日韩精品绯色| 国产精品资源在线看| 国产精品三级在线观看| 在线观看日韩电影| 毛片av中文字幕一区二区| 污片在线观看一区二区| 日韩av在线免费观看不卡| 国产日韩欧美精品电影三级在线| 亚洲成人免费在线| 日韩精品中文字幕一区| 亚洲成av人片一区二区三区| 日韩欧美一级二级三级久久久 | 国产欧美精品一区二区三区四区 | 国产91丝袜在线播放0| 亚洲国产综合在线| 精品捆绑美女sm三区| 欧美日韩一区二区三区视频| 高清在线成人网| 免费成人在线观看视频| 中文子幕无线码一区tr| 精品美女一区二区三区| 91黄色免费网站| 成人视屏免费看| 成人免费不卡视频| 99精品黄色片免费大全| 欧美天堂一区二区三区| 欧美午夜宅男影院| 色国产综合视频| 成人ar影院免费观看视频| 国产91丝袜在线观看| 国产91丝袜在线播放| 麻豆视频观看网址久久| 国产欧美精品一区二区色综合 | 五月天亚洲精品| 在线视频一区二区三区| 日韩福利电影在线观看| 亚洲高清免费观看高清完整版在线观看| 久久久精品国产免大香伊| 国产午夜精品理论片a级大结局| 久久综合九色欧美综合狠狠| 欧美哺乳videos| 久久久美女毛片| 成人欧美一区二区三区1314| 又紧又大又爽精品一区二区| 国产一区久久久| 91视频观看视频| 91福利视频在线| 久久人人超碰精品| 亚洲一区二区欧美日韩| 老汉av免费一区二区三区| 国产91丝袜在线观看| 91黄色免费版| 欧美大度的电影原声| 国产精品毛片高清在线完整版| 日韩理论片在线| 亚洲一区二区在线播放相泽| 午夜视频在线观看一区二区| 国产成人日日夜夜| 2022国产精品视频| 激情av综合网| 国产精品无人区| 国产精品一级在线| 国产亚洲欧美色| 成人免费毛片a| 国产精品成人免费在线| 国产成人免费在线观看不卡| 久久先锋资源网| 成人午夜又粗又硬又大| 国产欧美日产一区| 一本色道亚洲精品aⅴ| 亚洲国产三级在线| 欧美一区二区三区免费视频| 日韩福利电影在线| 久久久久久久网| 欧美中文字幕不卡| 六月婷婷色综合| 亚洲三级在线观看| 欧美一区二区播放| 成人爱爱电影网址| 一区av在线播放| 欧美电影免费观看高清完整版| 国产精品69久久久久水密桃 | 久久色在线视频| 日本韩国精品在线| 久久99精品久久久久久国产越南 | 另类的小说在线视频另类成人小视频在线 | 成人精品一区二区三区四区| 亚洲午夜三级在线| 国产精品美女一区二区| 日韩一级片在线观看| 91蝌蚪porny| 国产福利一区二区三区视频在线| 亚洲自拍欧美精品| 国产精品乱码人人做人人爱 | 国产乱码字幕精品高清av| 亚洲精品国产一区二区精华液| 欧美白人最猛性xxxxx69交| 欧美日韩高清一区二区不卡| 99久久er热在这里只有精品15| 精品综合久久久久久8888| 亚洲va欧美va国产va天堂影院| 亚洲色图视频免费播放| 一区在线播放视频| 国产精品久久久久毛片软件| 国产亚洲欧美日韩在线一区| 欧美成人激情免费网| 日本一区二区高清| 亚洲欧洲精品一区二区三区| 国产午夜精品一区二区| 日本一区二区成人| 亚洲一区国产视频| 免费成人结看片| 国产精品夜夜嗨| 99久久久无码国产精品| 97久久精品人人澡人人爽| 99久久伊人网影院| 欧美亚洲国产怡红院影院| 欧美精品丝袜中出| 精品国产欧美一区二区| 久久久久久99久久久精品网站| 中文字幕 久热精品 视频在线 | 久久夜色精品国产欧美乱极品| 久久久久97国产精华液好用吗| 国产精品久久久久久亚洲毛片 | 亚洲激情图片小说视频| 免费黄网站欧美| 成人网在线播放| 日韩欧美中文字幕一区| 亚洲欧美电影院| 狠狠色丁香婷综合久久| 在线观看91视频| 国产精品欧美极品| 日韩国产欧美在线播放| 色婷婷精品大视频在线蜜桃视频| 欧美xxx久久| 日韩精品电影一区亚洲| 成人18视频日本| 国产日韩欧美不卡| 精品在线一区二区三区| 91精品一区二区三区在线观看| 国产亚洲美州欧州综合国| 亚瑟在线精品视频| 亚洲久本草在线中文字幕| 91美女片黄在线观看91美女| 亚洲婷婷国产精品电影人久久| 国产91丝袜在线播放九色| 久久久久国产免费免费 | 日韩va亚洲va欧美va久久| 欧美日韩在线一区二区| 美女被吸乳得到大胸91| 亚洲国产精品v| 91精品国产综合久久久久久久| 国产在线一区观看| 亚洲成人在线免费| 国产精品不卡一区二区三区| 欧美少妇性性性| 亚洲va天堂va国产va久| 国产婷婷色一区二区三区四区| 91国产精品成人| 国产成人综合精品三级| 亚洲美女淫视频| 日韩三级免费观看| 一本久久精品一区二区| 亚洲国产wwwccc36天堂| 久久久噜噜噜久久中文字幕色伊伊| 国产高清久久久| 午夜视频一区在线观看| 自拍偷拍亚洲综合| www日韩大片| 欧美xxx久久| 欧美日本一区二区| 在线看国产一区二区| 国产成人精品免费一区二区| 日韩av成人高清| 亚洲一区二区三区精品在线| 国产三级一区二区| 精品国产青草久久久久福利| 6080午夜不卡| 欧美猛男男办公室激情| 欧美性猛片aaaaaaa做受| 色综合久久中文综合久久牛| 国产91高潮流白浆在线麻豆| 精品一二三四区| 精品一区二区三区视频| 美女网站在线免费欧美精品| 日韩精品一卡二卡三卡四卡无卡| 亚洲在线中文字幕|