本章討論如何監控 PostgreSQL 資料庫系統的磁碟使用情況。
每個資料表都有一個主要的 heap 磁碟檔案,其中儲存了大多數的資料。如果資料表中的任何欄位可能會有大量內容,則可能還會有一個與該資料表相關聯的 TOAST 欄位,該欄位用於儲存太大量而無法適當地容納在主資料表中的內容(請參閱第 73.3 節)。如果存在的話,TOAST 資料表上將有一個有效的索引。也可能會有與基本資料表關聯的索引。每個資料表和索引都會儲存在一個單獨的磁碟檔案中-如果檔案超過 1 GB,則可能有多個文檔案。這些檔案的命名規則的請參閱第 73.1 節。
您可以透過三種方式監控磁碟空間:使用 Table 9.94 中所列出的 SQL 函數,使用 oid2name 模組或對系統目錄進行手動檢查。SQL 函數最易於使用,通常建議使用。本節的其餘部分顯示如何透過檢查系統目錄來執行此操作。
在最近清理或分析的資料庫上使用 psql,可以發出查詢以查看任何資料表的磁碟使用情況:
每個頁面通常為 8 KB。(請記住,只有 VACUUM,ANALYZE 和一些 DDL 命令(如 CREATE INDEX)才能更新 relpages。)如果要直接檢查資料表的磁碟檔案,則需要使用檔案路徑名稱。
要顯示 TOAST 資料表所使用的空間,請使用如下的查詢:
您也可以輕鬆顯示索引大小:
使用以下語法可以很容易找到最大的資料表和索引:
資料庫管理員最重要的磁碟監控任務是確保磁碟空間是足夠的。充滿資料的資料磁碟不會導致資料損壞,但是可能限制繼續進行資料處理的活動。如果儲存 WAL 檔案的磁碟空間已滿,則資料庫伺服器會出現混亂,並因此而導致服務中斷。
如果無法透過刪除其他內容來釋放磁碟上的其他空間,則可以透過使用資料表空間將某些資料庫檔案移至其他檔案系統。有關更多資訊,請參閱第 23.6 節。
注意 有一些檔案系統在幾乎全滿時效能會很差,因此不要等到磁碟完全滿之後才採取措施。
如果您的系統支援使用者的磁碟配額,那麼資料庫自然會受到伺服器作為其執行使用者的配額限制。超過配額將帶來與完全用盡磁碟空間相同的不良影響。