亚洲女同成aV人片在线观看|亚洲www啪成人一区二区麻豆|亚洲国产中日韩精品综合|亚洲国产成人精品一级片|亚洲无码在线视频免费

您好,歡迎訪(fǎng)問(wèn)天津九安特機電工程有限公司!

17789947309

全國咨詢(xún)熱線(xiàn)

您現在所在位置: 主頁(yè) > 關(guān)鍵詞優(yōu)化

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

更新時(shí)間:2026-05-05 01:36:28

這篇文章主要介紹了PostgreSQL 如何查找需要收集的何查vacuum 表信息,具有很好的找需參考價(jià)值,希望對大家有所幫助。收集一起跟隨小編過(guò)來(lái)看看吧

前言

通常,信息在PostgreSQL中,何查由于經(jīng)常需要對表進(jìn)行 UPDATE 和 DELETE,找需因此表(biao)會(huì )產(chǎn)生碎片空間。收集

在 PostgreSQL中,信息使用VACUUM 僅僅對需要執行 VAC(′?ω?`)UUM 表將已刪除的何查空間標識為未使用,以便以后重用這些空間,找需但是收集不能立即將占用的空間返還給操作系統,因此需要使用(╯°□°)╯︵ ┻━┻ VACUUM FULL,信息才可以釋放空間,何查并立即將空間返還給操作系統。找??需

實(shí)現腳本

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

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ヽ(′▽?zhuān)?ノ_dead_cond bigint;
v_sql text;
cur_tablen(/ω\)ame 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='loop'
FE??TCH 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_con??d > 0 THEN
v_sql := 'INSERT INTO ' || v_vacuヽ(′ー`)ノum(′_`)_record || ' VALUES(' || chr(39) ||'VACUUM FULL ' || v_tablename ||';'|| chr(39) ||')';
EXECUTE v_sql;
END IF;(⊙_⊙)
EXIT WHEN NOT FOUND;
END loop='loop';
CLOSE cur_tablename;
END??;
$FUNCTIヽ(′ー`)ノON$
LANGUAGE PLPGSQL;

SHELL腳本

#!/bin/bash
#獲取環(huán)境變量
CURRDIR=$(cd "$(d??irname $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_VA?????CUUM_??TABLE_FUNCTION.??sql
source $CONFIG
CONNINFO='psql -U $USER -d $DBNAME -h $HOSTADDR -p $PORT'
function check_status()
{
echo "檢查數據庫服務(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??_fun??ction()
{
echo "創(chuàng )建收集需要 vacuum 表的函數"
$CONNINFO -f $CT_FUNCTION
}
check_(◎_◎;)status
create_table
create_function

執行方式??

postgres=# SELECT * FROM f_vacuum_ˉ\_(ツ)_/ˉtables();
f_vacuum_tables
-----------------

(1 row)
--創(chuàng )建測試表
postgres=# CREATE TABLE tab_test(id int);
--插入數據
postgres=# INSERT INTO tab_test SE??LECT id FROM generate_series(1,100000) as id;
INSERT 0 100000
--刪除數據
postgres=# DELETE FROM tab_T(???)est WHERE id <=ヽ(′ー`)ノ 10000;
DELETE 10002(?Д?)
postgres=# SELECT * FROM tab_vacuum_record ;
sqltext
----------??----(?⊿?)---------
VACUUM FULL tab_test??;
(1 row)

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

補充:Postgre(′ω`)SQL中 Vacuum 略談

VACUUM doc

路由清理

PostgreSQL 需(xu)要定期維護清理,一般都是由守護進(jìn)程自動(dòng)清理的,我們只是需要參數調優(yōu),也可以執行腳本定時(shí)去清理回收。

Vacuumming Basics

PG不得不對每張表進(jìn)行 Vacuum 命令,原因如下:

1、為了回收和再利用通過(guò)更新或者刪除行所占用的磁盤(pán)空間

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

3、為了更新只讀索引掃描的可見(jiàn)的集合

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

由于(′ω`)這些原因,在進(jìn)行頻繁的 VACUUM 操作時(shí)進(jìn)行規定:

標準 VACUUM

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

VACUUM FULL

a、可以回收大(da)量空間,但是(╯°□°)╯︵ ┻━┻比標準回收執行慢

b、運行時(shí)需要鎖表

VACUUM 運(yun)行會(huì )導致讀寫(xiě)性能比較差,所(′▽?zhuān)?以需要ヾ(′?`)?調整一些參數降低影響

temp_file_limit = -1 #默認-1ヾ(′▽?zhuān)??表示不限制每個(gè)進(jìn)程可使用的最大臨時(shí)文件限制,單位kb#max_filヽ(′ー`)ノes_per_process = 1000 #每個(gè)子進(jìn)程允許同時(shí)打開(kāi)文件的最大數量

在執行 VACUUM 和 ANYLYヽ(′?`)ノZE 期間,系統會(huì )維護一個(gè)用于估算各種I/O操作所消耗的內部計數器,當該值達到??vacuum_cost_limit的值時(shí),該進(jìn)程會(huì )休眠 vacuum_cost_delay 指定的時(shí)間,并重置計數器的值,繼續運行 VACUM 或者 ANYLヾ(^-^)ノYZE 操作

vacuum_cost_limit = 200 vacuum_cost_de(′_ゝ`)lay = 0 # 單位微秒,默認為 0 沒(méi)有開(kāi)啟

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

vacuum_cost_page_hit = 1 # 代表從緩存池查找共享的hash table并掃描 該`頁(yè)`的內容
#的估計值
vacuum_cost_page_miss = 10 # 0-10000 credit(′▽?zhuān)?s
vacuum_cost_page_dirty = 20

NOTE

當一張表中包含了大量數據時(shí),同時(shí)進(jìn)行刪除或者更新操作時(shí),V(?????)ACUUM 并不是最好的方案,

如果有該情況,則應該使用 VACUU FULL ,當執行 ALTER TABLE 時(shí),會(huì )重新(xin) COPY整

個(gè)表和重新構建索引,會(huì )進(jìn)行執行鎖,臨時(shí)占用和原始表大小(xiao)的磁盤(pán)空間,直到新數據COPY完成。

升級執行計劃

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

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

1defヽ(′▽?zhuān)?/ault_statistics_target = 100?? #提高查詢(xún)的 析計劃

文章來(lái)源:腳本之家

來(lái)源地址:https://www.jb51.net/article/205397.htm

在線(xiàn)客服

ONLINE SERVICE

聯(lián)系電話(huà)

13345193196

返回頂部
亚洲女同成aV人片在线观看|亚洲www啪成人一区二区麻豆|亚洲国产中日韩精品综合|亚洲国产成人精品一级片|亚洲无码在线视频免费 临澧县| 安宁市| 邳州市| 北票市| 浙江省| 桃园县| 保定市| 威信县| 永福县| 乐清市| 洱源县| 桃江县| 顺义区| 翁源县| 延寿县| 金川县| 房山区| 龙泉市| 竹溪县| 新和县| 榆社县| 寿光市| 南木林县| 新巴尔虎右旗| 明星| 凉城县| 屏南县| 郯城县| 祁阳县| 中山市| 虞城县| 从化市| 咸丰县| 桂东县| 庐江县| 涟水县| 永年县| 曲沃县| 府谷县| 镇远县| 永城市| http://444 http://444 http://444 http://444 http://444 http://444