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

主頁 > 知識庫 > PostgreSQL中的VACUUM命令用法說明

PostgreSQL中的VACUUM命令用法說明

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

每當(dāng)PostgreSQL數(shù)據(jù)庫中的表中的行被更新或刪除時(shí),死亡行會被遺留下來。VACUUM則會把它們除去來使空間能被重新利用。如果一個(gè)表沒有被清空,它會變得臃腫,浪費(fèi)磁盤空間而且會降低順序表掃描的速度,而且在較小范圍內(nèi)也會降低索引掃描的速度。

VACUUM命令只可以移除這些不再被需要的行版本(也被稱為元組)。如果被刪除事務(wù)的事務(wù)ID(存儲在xmax系統(tǒng)列中)比仍然活躍在PostgreSQL數(shù)據(jù)庫(或者共享表的整個(gè)集群)中最老的事務(wù)(xmin界限)更老,那么這個(gè)元組將不再被需要。

注意以下三種情況就可以抑制PostgreSQL集群中的xmin界限

1、 查找長時(shí)間運(yùn)行的事務(wù)

我們可以查找長時(shí)間運(yùn)行的事務(wù),然后使用pg_terminate_backend()函數(shù)去終止阻礙VACUUM命令的數(shù)據(jù)庫會話。

2、 查找復(fù)制槽

復(fù)制槽是一種數(shù)據(jù)結(jié)構(gòu),它使PostgreSQL服務(wù)器免于丟棄備用服務(wù)器仍然需要的信息。如果復(fù)制被推遲或者備用服務(wù)器被關(guān)閉,復(fù)制槽就會阻止VACUUM命令刪除舊的行。

復(fù)制槽提供了一種自動化的方式來確保主服務(wù)器不移除WAL塊直到它們被所有的從服務(wù)器接收。而且主服務(wù)器即使當(dāng)從服務(wù)器斷開連接時(shí)也不移除可能導(dǎo)致恢復(fù)沖突的行。

復(fù)制槽只保留已知所需數(shù)量的WAL塊而不是多于所需數(shù)量。

使用復(fù)制槽可以避免這個(gè)問題:在從服務(wù)器未連接的任意時(shí)間段內(nèi)不提供保護(hù)。

我們可以使用pg_drop_replication_slot()函數(shù)去丟棄不需要的復(fù)制槽。

這種情況只會發(fā)生在當(dāng)hot_standby_feedback參數(shù)設(shè)置為on時(shí)的物理復(fù)制中。如果是邏輯復(fù)制,那么會有一個(gè)相似的危險(xiǎn),但是只有系統(tǒng)目錄會被影響。

3、查找準(zhǔn)備好的事務(wù)

二階段提交協(xié)議是一種原子性確認(rèn)協(xié)議。它是一種分布式算法,用來協(xié)調(diào)參與分布式原子事務(wù)的所有進(jìn)程,確定是否提交或者終止(回滾)這個(gè)事務(wù)。

在二階段提交過程中,一個(gè)分布式事務(wù)首先使用PREPARE TRANSACTION,為二階段提交準(zhǔn)備當(dāng)前事務(wù)。如果由于任何原因PREPARE TRANSACTION 命令失敗,會變成ROLLBACK,而當(dāng)前事務(wù)則會被取消。

然后我們使用COMMIT PREPARED,提交一個(gè)之前為兩階段提交預(yù)備的事務(wù)。

一旦一個(gè)事務(wù)被準(zhǔn)備好,它會一直保持一種“游蕩”狀態(tài)直到被提交或者中止。通常情況下,事務(wù)不會在準(zhǔn)備狀態(tài)中保持很長時(shí)間,但有時(shí)會出現(xiàn)錯(cuò)誤所以事務(wù)必須被管理員手動移除。

我們也可以使用ROLLBACK PREPARED,取消一個(gè)之前為兩階段提交準(zhǔn)備好的事務(wù)。

補(bǔ)充:postgresql vacuum操作

PostgreSQL數(shù)據(jù)庫管理工作中,定期vacuum是一個(gè)重要的工作.

vacuum的效果

1.1釋放,再利用 更新/刪除的行所占據(jù)的磁盤空間.

1.2更新POSTGRESQL查詢計(jì)劃中使用的統(tǒng)計(jì)數(shù)據(jù)

1.3防止因事務(wù)ID的重置而使非常老的數(shù)據(jù)丟失。

第一點(diǎn)的原因是PostgreSQL數(shù)據(jù)的插入,更新,刪除操作并不是真正放到數(shù)據(jù)庫空間.如果不定期釋放空間的話,由于數(shù)據(jù)太多,查詢速度會巨降.

第二點(diǎn)的原因是PostgreSQL在做查詢處理的時(shí)候,為了是查詢速度提高,會根據(jù)統(tǒng)計(jì)數(shù)據(jù)來確定執(zhí)行計(jì)劃.如果不及時(shí)更新的話,查詢的效果可能不如預(yù)期.

第三點(diǎn)的原因是PostgreSQL中每一個(gè)事務(wù)都會產(chǎn)生一個(gè)事務(wù)ID,但這個(gè)數(shù)字是有上限的. 當(dāng)事務(wù)ID達(dá)到最大值后,會重新從最小值開始循環(huán).這樣如果不及時(shí)把以前的數(shù)據(jù)釋放掉的話,原來的老數(shù)據(jù)會因?yàn)槭聞?wù)ID的丟失而丟失掉.

雖然在新版本的Postgresql中有自動的vacuum,但是如果是大批量的數(shù)據(jù)IO可能會導(dǎo)致自動執(zhí)行很慢,需要配合手動執(zhí)行以及自己的腳本來清理數(shù)據(jù)庫。

1. vacuumdb 是 SQL 命令 VACUUM的封裝

所以用vacuumdb和vacuum來清理數(shù)據(jù)庫都可以,效果是一樣的。

2.vacuumdb 中的幾個(gè)重要參數(shù)

可以用vacuumdb --help查詢。

-a/--all vacuum所有的數(shù)據(jù)庫

-d dbname 只vacuum dbname這個(gè)數(shù)據(jù)庫

-f/--full 執(zhí)行full的vacuum

-t table 只vacuum table這個(gè)數(shù)據(jù)表

-z/--analyze Calculate statistics for use by the optimizer

3. 切換到postgres用戶下

vacuumdb -d yourdbname -f -z -v 來清理你的數(shù)據(jù)庫。

或者加到conrtab中15 1 * * * postgres vacuumdb -d mydb -f -z -v >> /tmp/vacuumdb.log

每天的一點(diǎn)一刻開始進(jìn)行清理。

4. 如何查詢我的XID是否接近臨界值的命令:

select age(datfrozenxid) from pg_database;

或者:

select max(age(datfrozenxid)) from pg_database;

5. 然而我們關(guān)心的是哪一個(gè)大的表組要真正的vacuum

SELECT relname, age(relfrozenxid) as xid_age, pg_size_pretty(pg_table_size(oid)) as table_size FROM pg_class WHERE relkind = 'r' and pg_table_size(oid) > 1073741824
ORDER BY age(relfrozenxid) DESC LIMIT 20;

這個(gè)命令是查詢按照最老的XID排序,查看大于1G而且是排名前20的表。

下面是一個(gè)例子:

relname | xid_age | table_size
------------------------+-----------+------------
postgres_log | 199785216 | 12 GB
statements | 4551790 | 1271 MB
normal_statement_times | 31 | 12 GB

然后你可以單獨(dú)每個(gè)表進(jìn)行vacuum:

vacuumdb --analyze --verbose --table 'postgres_log' mydb

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

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL中的VACUUM命令用法說明》,本文關(guān)鍵詞  PostgreSQL,中的,VACUUM,命令,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(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)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日韩二区三区在线观看| 国产精品18久久久久久久久久久久| 亚洲午夜精品一区二区三区他趣| 国产亚洲精品bt天堂精选| 91精品国产综合久久小美女| 欧美军同video69gay| 国模娜娜一区二区三区| 久99久精品视频免费观看| 久久成人免费日本黄色| 国产一区二区伦理| 国产成人av电影在线| 99视频在线精品| 在线观看日韩av先锋影音电影院| 在线视频中文字幕一区二区| 欧美男女性生活在线直播观看| 欧美一区二区三区免费观看视频| 日韩午夜电影在线观看| 精品国产一区二区三区不卡| 久久亚洲一区二区三区四区| 国产精品伦理一区二区| 亚洲综合一区二区精品导航| 欧美日韩精品三区| 日韩欧美的一区| 国产午夜精品一区二区三区嫩草| 日韩一区中文字幕| 日韩极品在线观看| 国产精品 欧美精品| 色av一区二区| 91麻豆精品国产91久久久资源速度| 欧美日免费三级在线| 日韩视频在线观看一区二区| 欧美激情一区二区三区全黄| 亚洲一区二区精品3399| 久久精品国产亚洲高清剧情介绍 | 日韩精品中文字幕在线一区| 久久久久国产精品麻豆ai换脸| 中文字幕av一区二区三区免费看| 国产精品无码永久免费888| 欧美另类z0zxhd电影| 欧美国产日韩在线观看| 日本欧美一区二区在线观看| 中文字幕av不卡| 蜜臀精品久久久久久蜜臀| 成人aa视频在线观看| 91精品国产品国语在线不卡| 中文字幕在线观看不卡| 精品亚洲国产成人av制服丝袜| 99久久精品99国产精品| 欧美午夜电影在线播放| 久久久久久久久久电影| 午夜精彩视频在线观看不卡| av不卡在线观看| 欧美变态tickling挠脚心| 日本欧美一区二区在线观看| 94-欧美-setu| 久久久久99精品一区| 免费的成人av| 欧美日韩一级大片网址| 亚洲女与黑人做爰| 大白屁股一区二区视频| 久久色在线观看| 蜜桃一区二区三区在线| 精品视频全国免费看| 欧美影院精品一区| 亚洲男女一区二区三区| 高清成人在线观看| 国产色一区二区| 国产综合色在线| 精品久久一区二区| 久久精品国产在热久久| 91精品中文字幕一区二区三区| 亚洲一区在线观看免费观看电影高清| 久久国产视频网| 日韩精品中文字幕在线不卡尤物| 首页国产丝袜综合| 欧美久久久久中文字幕| 性感美女久久精品| 性做久久久久久久久| 欧美色男人天堂| 亚洲福利视频导航| 欧美剧在线免费观看网站| 亚洲国产aⅴ天堂久久| 欧美在线免费视屏| 亚洲成人激情自拍| 欧美日韩一区二区在线观看| 欧美熟乱第一页| 久久99热99| 99精品欧美一区| 99久久99久久久精品齐齐| 国产精品久久久久三级| 成人国产在线观看| 一区二区三区久久| 在线播放视频一区| 国产一区二区三区| 综合网在线视频| 国产在线一区二区| 久久国产精品免费| 91精品国产综合久久福利软件| 日韩欧美一区中文| 亚洲欧洲国产专区| 在线欧美小视频| 视频一区视频二区中文| 日韩三级免费观看| 久草在线在线精品观看| 亚洲国产精品激情在线观看| 色8久久人人97超碰香蕉987| 日韩二区三区四区| 中文乱码免费一区二区| 欧美日韩不卡在线| 国产成人精品亚洲777人妖| 一区二区三区国产精华| 另类成人小视频在线| 亚洲欧洲成人av每日更新| 亚洲成人1区2区| 日韩欧美电影一二三| 91福利在线导航| 国产一区二区三区在线看麻豆| √…a在线天堂一区| 欧美sm极限捆绑bd| 欧美一级欧美一级在线播放| 亚洲成人免费av| 国产精品乱码久久久久久| 欧美一级理论性理论a| 一本色道**综合亚洲精品蜜桃冫 | 99视频在线精品| 久久精品国产精品亚洲精品| 综合久久国产九一剧情麻豆| 精品1区2区在线观看| 欧美日韩欧美一区二区| 91蝌蚪porny| 国产高清精品网站| 美女视频一区二区| 亚洲已满18点击进入久久| 国产精品美女久久久久久久久| 日韩欧美高清dvd碟片| 欧洲国内综合视频| 亚洲精品成人天堂一二三| 欧美激情一区二区三区蜜桃视频| 欧美一二三四在线| 欧美天堂一区二区三区| 日本韩国一区二区| 91在线你懂得| 91网址在线看| 9人人澡人人爽人人精品| 精品一区中文字幕| 国产一区免费电影| 性感美女久久精品| 亚洲高清不卡在线| 亚洲成在线观看| 亚洲一区二区三区爽爽爽爽爽| 亚洲日本电影在线| 亚洲人午夜精品天堂一二香蕉| 国产精品18久久久久久久久| 国产一区二区三区高清播放| 国产一区在线视频| 国产传媒久久文化传媒| 国产成人精品www牛牛影视| 国产成人夜色高潮福利影视| 国产精品香蕉一区二区三区| 国产精品一品二品| aa级大片欧美| 91国产视频在线观看| 欧美日韩一二区| 欧美一区二区三区四区高清| 精品少妇一区二区三区| 久久嫩草精品久久久久| 成人精品国产免费网站| 91视频在线观看免费| 精品视频在线看| 精品久久久久香蕉网| 欧美激情一区二区三区四区| 一区二区视频在线| 日本视频一区二区| 国产成人在线免费观看| 91视频.com| 欧美第一区第二区| 欧美成人猛片aaaaaaa| 国产日韩欧美不卡在线| 亚洲免费观看高清完整版在线观看 | aaa亚洲精品一二三区| 欧美日韩日本视频| 久久综合久久久久88| 18成人在线视频| 美女视频黄a大片欧美| 国产成人aaa| 欧美精品久久99久久在免费线| 精品国产91洋老外米糕| 亚洲精品亚洲人成人网在线播放| 日本成人在线网站| 97精品久久久久中文字幕| 欧美精品在线一区二区| 国产精品乱码一区二区三区软件| 亚洲成av人片一区二区三区| 国产成人av一区二区三区在线| 欧美在线影院一区二区| 久久免费看少妇高潮| 日本不卡视频一二三区| 92精品国产成人观看免费| 久久先锋影音av鲁色资源网| 亚洲成人在线免费|