日韩小视频-日韩久久一区二区三区-日韩久久一级毛片-日韩久久久精品中文字幕-国产精品亚洲精品影院-国产精品亚洲欧美云霸高清

下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當(dāng)前位置:軟件下載吧 > 技術(shù)開發(fā) > 數(shù)據(jù)庫 > 一文帶你搞懂PostgreSQL中的VACUUM命令用法

一文帶你搞懂PostgreSQL中的VACUUM命令用法

時(shí)間:2024-02-03 17:42作者:下載吧人氣:37

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

VACUUM命令只可以移除這些不再被需要的行版本(也被稱為元組)。如果被刪除事務(wù)的事務(wù)ID(存儲(chǔ)在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ù)庫會(huì)話。

2、 查找復(fù)制槽

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

復(fù)制槽提供了一種自動(dòng)化的方式來確保主服務(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ù)制槽。

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

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 命令失敗,會(huì)變成ROLLBACK,而當(dāng)前事務(wù)則會(huì)被取消。

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

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

我們也可以使用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ù)太多,查詢速度會(huì)巨降.

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

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

雖然在新版本的Postgresql中有自動(dòng)的vacuum,但是如果是大批量的數(shù)據(jù)IO可能會(huì)導(dǎo)致自動(dòng)執(zhí)行很慢,需要配合手動(dòng)執(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

標(biāo)簽MySQL,技術(shù)文檔,數(shù)據(jù)庫,PostgreSQL

相關(guān)下載

查看所有評(píng)論+

網(wǎng)友評(píng)論

網(wǎng)友
您的評(píng)論需要經(jīng)過審核才能顯示

熱門閱覽

最新排行

公眾號(hào)

主站蜘蛛池模板: 精品久久久久久久久久久久久久久 | 中文字幕日韩精品有码视频 | 性做久久久久免费观看 | 国产精品亚洲专一区二区三区 | 欧美日韩国产免费一区二区三区 | 在线视频观看免费视频18 | 男人天堂网2022 | 美女很黄很黄是免费的·无遮挡网站 | 亚欧美图片自偷自拍另类 | 日本男人天堂 | 性感美女香蕉视频 | 欧美xo影院 | 国产三级三级三级三级 | 欧美毛片性视频区 | 成人久久18免费网站游戏 | 久草福利资源网站免费 | 国产一区二区在线播放 | 亚洲黄色免费网址 | 中文字幕亚洲欧美日韩不卡 | 午夜三级网站 | 能直接看的一级欧美毛片 | 亚洲一区二区三区在线播放 | 国产综合在线视频 | 日本韩国一级 | 手机看片1024欧美日韩你懂的 | 一级爱爱片一级毛片-一毛 一级爱做片免费观看久久 一级白嫩美女毛片免费 | 日韩不卡一区二区 | 免费高清一级欧美片在线观看 | 在线综合+亚洲+欧美中文字幕 | 一级做性色a爰片久久毛片免费 | 欧美毛片性视频区 | 成年人视频在线观看免费 | 一区二区三区在线免费视频 | 国产人成午夜免视频网站 | 国产午夜精品免费一二区 | 亚洲视频三级 | 亚洲精品国产专区一区 | 最新国产三级在线观看不卡 | 日韩精品中文字幕一区二区三区 | 三级黄色高清视频 | 成 人 黄 色 大 片 |