婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

前言

通常,在PostgreSQL中,由于經(jīng)常需要對表進行 UPDATE 和 DELETE,因此表會產(chǎn)生碎片空間。

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

實現(xiàn)腳本

記錄收集表創(chuàng)建

CREATE TABLE IF NOT EXISTS tab_vacuum_record
(sqltext text);

收集需要VACUUM 表函數(shù)

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
#獲取環(huán)境變量
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 "檢查數(shù)據(jù)庫服務(wù)器狀態(tài)是否正常 !"
    stat=`$CONNINFO -Aqt -c 'SELECT 1'`
    if [ "${stat}" == "1" ];then
        echo "服務(wù)器連接正常"
    else
        echo "服務(wù)器連接異常,退出"
        exit -1;
    fi
}
function create_table()
{
    echo "創(chuàng)建收集需要vacuum的表"
    $CONNINFO -f $CT_FILE
}
function create_function()
{
    echo "創(chuàng)建收集需要 vacuum 表的函數(shù)"
    $CONNINFO -f $CT_FUNCTION
}
check_status
create_table
create_function

執(zhí)行方式

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

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

補充:PostgreSQL中 Vacuum 略談

VACUUM doc

路由清理

PostgreSQL 需要定期維護清理,一般都是由守護進程自動清理的,我們只是需要參數(shù)調(diào)優(yōu),也可以執(zhí)行腳本定時去清理回收。

Vacuumming Basics

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

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

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

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

4、避免由于事務(wù)ID或者混合事務(wù)ID丟失歷史數(shù)據(jù)

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

標(biāo)準(zhǔn) VACUUM

進行回收時,生產(chǎn)環(huán)境不影響數(shù)據(jù)庫庫的正常使用(SELECT、INSERT、UPDATE、DELETE),并行使用,清理時不允許對表結(jié)構(gòu)進行修改(ALTER TABLE)推薦使用該方案

VACUUM FULL

a、可以回收大量空間,但是比標(biāo)準(zhǔn)回收執(zhí)行慢

b、運行時需要鎖表

VACUUM 運行會導(dǎo)致讀寫性能比較差,所以需要調(diào)整一些參數(shù)降低影響

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

在執(zhí)行 VACUUM 和 ANYLYZE 期間,系統(tǒng)會維護一個用于估算各種I/O操作所消耗的內(nèi)部計數(shù)器,當(dāng)該值達到vacuum_cost_limit的值時,該進程會休眠 vacuum_cost_delay 指定的時間,并重置計數(shù)器的值,繼續(xù)運行 VACUM 或者 ANYLYZE 操作

vacuum_cost_limit = 200 
vacuum_cost_delay = 0 # 單位微秒,默認(rèn)為 0 沒有開啟

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

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

NOTE

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

如果有該情況,則應(yīng)該使用 VACUU FULL ,當(dāng)執(zhí)行 ALTER TABLE 時,會重新 COPY整

個表和重新構(gòu)建索引,會進行執(zhí)行鎖,臨時占用和原始表大小的磁盤空間,直到新數(shù)據(jù)COPY完成。

升級執(zhí)行計劃

執(zhí)行計劃通過自己或者 VACUUM調(diào)用命令 ANALYZE 收集統(tǒng)計,

創(chuàng)建 表達式索引 能夠提高查詢執(zhí)行計劃

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

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

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

標(biāo)簽:齊齊哈爾 臨滄 通化 阜陽 海北 荊州 那曲 泰州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL 如何查找需要收集的vacuum 表信息》,本文關(guān)鍵詞  PostgreSQL,如何,查找,需要,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PostgreSQL 如何查找需要收集的vacuum 表信息》相關(guān)的同類信息!
  • 本頁收集關(guān)于PostgreSQL 如何查找需要收集的vacuum 表信息的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产视频一区不卡| 色av成人天堂桃色av| 亚洲成人av一区| 夜夜嗨av一区二区三区中文字幕| 欧美大片在线观看| 久久综合色鬼综合色| 精品久久久网站| 国产三级欧美三级日产三级99| 26uuu欧美| 国产精品素人一区二区| 成人欧美一区二区三区视频网页| 一区免费观看视频| 亚洲香蕉伊在人在线观| 日韩av一区二区在线影视| 免费人成黄页网站在线一区二区 | 国产电影精品久久禁18| 国产91精品免费| 色爱区综合激月婷婷| 欧美一级片免费看| 国产日韩欧美一区二区三区乱码 | 欧美精品一区二区久久婷婷| 久久久久久**毛片大全| 亚洲欧美在线视频观看| 天天操天天色综合| 国产精品91xxx| 色欧美88888久久久久久影院| 欧美日韩精品久久久| 久久久久亚洲综合| 亚洲最快最全在线视频| 国内外精品视频| 欧美三级三级三级爽爽爽| 日韩免费视频一区| 亚洲乱码国产乱码精品精的特点| 天天色图综合网| 91在线一区二区| 欧美精品一区在线观看| 亚洲图片欧美视频| 粉嫩欧美一区二区三区高清影视| 欧美色视频一区| 欧美国产在线观看| 麻豆成人免费电影| 欧美日韩一区二区三区在线看 | 日韩电影免费在线观看网站| 国产91精品一区二区麻豆网站| 在线播放一区二区三区| 国产精品久久久久久久裸模| 日韩精品一级二级 | 国产精品你懂的| 久久精品国产成人一区二区三区| 99在线视频精品| 国产欧美一区二区三区在线看蜜臀 | 92国产精品观看| 久久久久久久综合日本| 日韩精品一卡二卡三卡四卡无卡| 91色porny在线视频| 中文字幕免费一区| 国产精品一区2区| 欧美tickling挠脚心丨vk| 亚洲国产成人tv| 91福利在线播放| 一区二区在线观看视频在线观看| 成人免费视频视频| 欧美经典一区二区| 国产高清在线观看免费不卡| 精品电影一区二区三区| 极品美女销魂一区二区三区 | 欧美日韩国产综合久久| 亚洲人成亚洲人成在线观看图片| 国产 日韩 欧美大片| 久久久久一区二区三区四区| 国产主播一区二区三区| 欧美岛国在线观看| 国产九色sp调教91| 日本一区免费视频| 高清视频一区二区| 国产精品嫩草影院av蜜臀| 不卡电影免费在线播放一区| 国产精品久久久久久久久久久免费看| 国产成人午夜电影网| 国产清纯在线一区二区www| 国产成人激情av| 中文字幕一区三区| 欧美午夜电影一区| 免费不卡在线观看| 国产欧美日韩中文久久| 99久久综合狠狠综合久久| 国产精品成人在线观看| 欧美午夜视频网站| 久久精品国产成人一区二区三区 | 丁香一区二区三区| 亚洲视频香蕉人妖| 欧美伦理电影网| 精品在线亚洲视频| 亚洲色图.com| 日韩一区二区三区电影| 国产精品99久久久久久似苏梦涵| 中文字幕在线一区二区三区| 在线观看亚洲一区| 国产精品亚洲综合一区在线观看| 亚洲欧洲在线观看av| 欧美日韩免费观看一区三区| 国产一区二区三区综合| 亚洲激情五月婷婷| 日韩一级视频免费观看在线| 成人精品电影在线观看| 日韩精品一卡二卡三卡四卡无卡| 欧美国产在线观看| 91精品国产综合久久福利软件| 国产成人午夜电影网| 天天影视涩香欲综合网| 国产精品入口麻豆九色| 欧美一区二区日韩| 91在线精品一区二区| 国产一区二区三区观看| 亚洲最新在线观看| 国产欧美日韩一区二区三区在线观看| 欧美日韩午夜在线视频| 成人美女在线视频| 国内精品伊人久久久久av一坑 | 国产一本一道久久香蕉| 亚洲精品伦理在线| 国产日韩欧美一区二区三区乱码| 欧美精品一级二级三级| 99久久精品国产网站| 国产精品亚洲一区二区三区在线 | 欧美成人精精品一区二区频| 日本韩国精品一区二区在线观看| 国产精品一二一区| 韩国视频一区二区| 日韩高清不卡在线| 亚洲电影一区二区三区| 亚洲伦在线观看| 亚洲欧洲韩国日本视频| 国产精品色呦呦| 国产精品日日摸夜夜摸av| 久久蜜桃av一区精品变态类天堂 | 国产精品一卡二卡| 国产一区二区三区最好精华液 | 欧美高清在线精品一区| 久久众筹精品私拍模特| 欧美一级理论性理论a| 欧美午夜电影在线播放| 欧美主播一区二区三区| 91色视频在线| 91九色最新地址| 欧美亚洲高清一区二区三区不卡| 91在线一区二区三区| 91黄色激情网站| 91久久免费观看| 欧美日本在线一区| 欧美日韩另类国产亚洲欧美一级| 欧美日韩亚洲国产综合| 欧美色综合天天久久综合精品| 色丁香久综合在线久综合在线观看| 色综合久久综合网欧美综合网| 色狠狠色噜噜噜综合网| 欧洲av一区二区嗯嗯嗯啊| 欧美少妇一区二区| 日韩免费福利电影在线观看| 久久久久久久电影| 国产精品传媒在线| 午夜伊人狠狠久久| 久久99精品国产.久久久久久 | 欧美影视一区二区三区| 欧美视频一区二区在线观看| 欧美一区二区在线观看| 久久综合久久鬼色| 亚洲欧美国产高清| 男人的天堂久久精品| 国产麻豆9l精品三级站| 91亚洲国产成人精品一区二区三 | 精品一区二区日韩| 成人性色生活片| 欧美日韩黄色一区二区| 精品国产一区二区三区忘忧草| 国产欧美精品国产国产专区| 亚洲国产毛片aaaaa无费看| 蜜臀99久久精品久久久久久软件| 国产成人午夜视频| 欧美日韩电影一区| 日本一区二区免费在线| 亚洲电影在线免费观看| 国产成人亚洲精品青草天美| 欧美性受xxxx黑人xyx性爽| 欧美不卡一二三| 一区二区久久久久久| 韩国毛片一区二区三区| 欧美三级中文字幕在线观看| 久久久久青草大香线综合精品| 亚洲视频1区2区| 久久er99精品| 欧美高清性hdvideosex| 中文字幕综合网| 国产在线视频一区二区三区| 欧美日韩美女一区二区| 亚洲天堂精品在线观看| 国产一区二区三区美女| 欧美精品日韩综合在线| 亚洲欧美aⅴ...| 成人av在线资源网站|