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

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

軟件下載吧

當前位置:軟件下載吧 > 技術開發 > 數據庫 > 一文帶你搞懂PostgreSQL中的VACUUM命令用法

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

時間:2024-02-03 17:42作者:下載吧人氣:42

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

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

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

1、 查找長時間運行的事務

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

2、 查找復制槽

復制槽是一種數據結構,它使PostgreSQL服務器免于丟棄備用服務器仍然需要的信息。如果復制被推遲或者備用服務器被關閉,復制槽就會阻止VACUUM命令刪除舊的行。

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

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

使用復制槽可以避免這個問題:在從服務器未連接的任意時間段內不提供保護。

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

這種情況只會發生在當hot_standby_feedback參數設置為on時的物理復制中。如果是邏輯復制,那么會有一個相似的危險,但是只有系統目錄會被影響。

3、查找準備好的事務

二階段提交協議是一種原子性確認協議。它是一種分布式算法,用來協調參與分布式原子事務的所有進程,確定是否提交或者終止(回滾)這個事務。

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

然后我們使用COMMIT PREPARED,提交一個之前為兩階段提交預備的事務。

一旦一個事務被準備好,它會一直保持一種“游蕩”狀態直到被提交或者中止。通常情況下,事務不會在準備狀態中保持很長時間,但有時會出現錯誤所以事務必須被管理員手動移除。

我們也可以使用ROLLBACK PREPARED,取消一個之前為兩階段提交準備好的事務。

補充:postgresql vacuum操作

PostgreSQL數據庫管理工作中,定期vacuum是一個重要的工作.

vacuum的效果

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

1.2更新POSTGRESQL查詢計劃中使用的統計數據

1.3防止因事務ID的重置而使非常老的數據丟失。

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

第二點的原因是PostgreSQL在做查詢處理的時候,為了是查詢速度提高,會根據統計數據來確定執行計劃.如果不及時更新的話,查詢的效果可能不如預期.

第三點的原因是PostgreSQL中每一個事務都會產生一個事務ID,但這個數字是有上限的. 當事務ID達到最大值后,會重新從最小值開始循環.這樣如果不及時把以前的數據釋放掉的話,原來的老數據會因為事務ID的丟失而丟失掉.

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

1. vacuumdb 是 SQL 命令 VACUUM的封裝

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

2.vacuumdb 中的幾個重要參數

可以用vacuumdb –help查詢。

-a/–all vacuum所有的數據庫

-d dbname 只vacuum dbname這個數據庫

-f/–full 執行full的vacuum

-t table 只vacuum table這個數據表

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

標簽MySQL,技術文檔,數據庫,PostgreSQL

相關下載

查看所有評論+

網友評論

網友
您的評論需要經過審核才能顯示

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 日韩美女一级视频 | 亚洲天堂网视频 | 搞黄网站在线观看 | 国产欧美日韩在线一区二区不卡 | 国产精品1区 2区 3区 | 欧美一级片免费 | 国产区更新 | 欧美成人高清在线视频大全 | 国产在线观看免费一级 | 国产成a人片在线观看视频 国产成版人视频网站免费下 | 中文一级毛片 | 免费观看欧美一级毛片 | 欧美一区二区三区在线 | 欧美成人看片一区二区三区尤物 | 日本三级在线观看中文字 | 国产v片在线播放免费观 | 92精品国产成人观看免费 | 久久精品中文字幕第一页 | 亚洲人成一区二区三区 | 中文字幕日韩三级 | 黄色三级在线 | 免费a级毛片大学生免费观看 | 精品欧美小视频在线观看 | 欧美日韩亚洲国产精品 | 一区二区三区免费看 | 亚洲成人黄色在线 | 日韩视频在线观看 | 91久久精品国产亚洲 | 欧美精品一区二区三区免费观看 | 午夜国产精品久久久久 | 亚洲高清自拍 | 中文字幕亚洲日本岛国片 | 一级视频在线观看 | 99r精品视频| 亚洲一区二区三区福利在线 | 午夜爽爽性刺激一区二区视频 | 一级黄色香蕉视频 | 久久er精品视频 | 国产欧美日韩精品在线 | 亚洲精品国产字幕久久不卡 | 亚洲精品国产一区二区三区四区 |