PostgreSQL 中 pg_wal文件過多過大的清理方法及關鍵注意事項的總結

PostgreSQL 中 pg_wal文件過多過大的清理方法及關鍵注意事項的總結

以下是針對 PostgreSQL 中 pg_wal 文件過多過大的清理方法及關鍵注意事項的總結

一、安全清理 WAL 文件的完整流程

1. 確認數據庫和備份完整性
  • 備份驗證:確保最近的物理備份(如 pg_basebackup)或邏輯備份(如 pg_dump)可用,并測試恢復流程。
  • 監控工具:使用 pg_verifybackup(PG 13+)驗證備份一致性。
2. 檢查 WAL 文件使用情況
  • 查看 WAL 生成速率

    SELECT * FROM pg_stat_bgwriter;
    

    重點關注 buffers_alloc(WAL 緩沖區分配次數)和 buffers_backend(后端直接寫入的緩沖區數),若數值持續增長,可能需優化寫入負載或調整檢查點參數。

  • 查看當前 WAL 活動

    SELECT pg_walfile_name(pg_current_wal_lsn()) AS current_wal_file;
    
3. 停止寫入操作(可選)
  • 在維護窗口期間暫停寫入(如關閉應用連接),避免新 WAL 干擾清理過程。
4. 觸發檢查點并清理舊 WAL
  • 手動觸發檢查點

    CHECKPOINT;
    

    確保舊 WAL 文件標記為可回收。

  • 使用 pg_archivecleanup

    pg_archivecleanup /path/to/archive 000000010000000000000027
    

    清理指定文件之前的 WAL 歸檔(需在 archive_command 配置正確的情況下使用)。

5. 識別可刪除的 WAL 文件
  • 查找檢查點位置

    pg_controldata /path/to/data | grep "Latest checkpoint's REDO location"
    

    保留該位置及之后的所有 WAL 文件。

  • 示例分析

    • 若當前寫入文件為 000000010000000000000027,而目錄中最大文件為 00000001000000000000002B,說明 00000002B 是之前檢查點重命名的舊文件,可能可刪除。但需通過 pg_controldata 的檢查點位置確認。
6. 調整參數優化 WAL 管理
# postgresql.conf
max_wal_size = 16GB          # 根據寫入負載調整(建議逐步增加)
min_wal_size = 4GB           # 保留的最小 WAL 大小
checkpoint_timeout = 30min    # 延長檢查點間隔
checkpoint_completion_target = 0.9  # 平滑寫入負載
7. 處理復制槽與歸檔故障
  • 檢查復制槽

    SELECT slot_name, active, restart_lsn FROM pg_replication_slots;
    

    restart_lsn 長期未更新,需排查下游復制延遲或刪除無效槽。

  • 歸檔狀態監控

    SELECT * FROM pg_stat_archiver;
    

    確保 last_failed_wal 為空,否則檢查歸檔腳本或存儲空間。


二、關鍵注意事項

1. 避免手動刪除 WAL 文件
  • 風險:直接刪除 pg_wal 目錄下的文件可能導致數據庫無法啟動或數據丟失。
  • 例外情況:僅在極端情況下(如磁盤已滿且無法觸發檢查點)手動清理:
    1. 停止 PostgreSQL 服務。
    2. 根據 pg_controldata 的檢查點位置,保留所有比該位置新的 WAL 文件。
    3. 重啟服務。
2. WAL 文件循環機制
  • PostgreSQL 會重用舊 WAL 文件(通過重命名),因此文件序號可能不連續。
  • 不要依賴文件名順序:始終通過 pg_current_wal_lsn()pg_controldata 確定有效文件。
3. 監控與自動化
  • 設置告警:監控 pg_wal 目錄大小(如通過 Prometheus 的 pg_stat_archiver 指標)。
  • 定期維護:結合工具(如 pg_cron)定期執行 CHECKPOINTpg_archivecleanup

三、示例操作:安全清理未歸檔的 WAL

場景pg_wal 目錄占用 100GB,歸檔因存儲故障已停止。
  1. 停止數據庫寫入(可選):暫停應用連接。

  2. 觸發檢查點

CHECKPOINT;
  1. 查找可清理的 WAL 文件
pg_controldata /var/lib/postgresql/12/main | grep "Latest checkpoint's REDO location"
# 輸出:Latest checkpoint's REDO location: 0/2B000000
  1. 保留必要文件
  • 所有文件名 LSN >= 0/2B000000 的文件需保留。
  • 刪除更舊的文件(如 000000010000000000000027 前)。
  1. 重啟服務(若手動刪除):
systemctl restart postgresql

四、常見問題解答

Q1: 為什么 pg_wal 目錄中最大的文件不是當前寫入的文件?
  • PostgreSQL 會循環重用舊文件(重命名),因此文件序號可能跳躍。始終通過 pg_current_wal_lsn() 確認當前活動文件。
Q2: 如何避免未來 WAL 膨脹?
  • 調整 max_wal_sizecheckpoint_timeout
  • 監控復制槽和歸檔狀態。
  • 使用 wal_compression = on(PG 13+)減少 WAL 體積。
Q3: pg_archivecleanup 報錯 “invalid WAL file name”?
  • 確保參數傳遞正確,且歸檔目錄路徑有效。文件名必須為完整的 WAL 文件名(如 000000010000000000000027)。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/92248.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/92248.shtml
英文地址,請注明出處:http://en.pswp.cn/web/92248.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Django事務支持

1.事務概念 事務是一組不可分割的操作序列,這些操作要么全部執行,要么全部不執行。事務具有四個關鍵屬性,通常稱為 ACID 特性: 原子性(Atomicity):事務是一個不可分割的工作單位,事務…

<form> + <iframe> 方式下載大文件的機制

使用 <form> <iframe> 方式下載大文件的機制之所以穩定&#xff0c;核心在于其?分塊傳輸?和?瀏覽器沙箱隔離?設計。以下是技術原理詳解&#xff1a; 一、底層工作機制 ?分塊傳輸協議? 表單提交后&#xff0c;服務器按 Transfer-Encoding: chunked 分塊返回數…

Python--OCR(2)

一、明確 OCR 任務邊界首先定義 OCR 系統的核心目標&#xff1a;場景&#xff1a;印刷體&#xff08;如文檔、發票&#xff09;/ 手寫體&#xff08;如筆記&#xff09;/ 特定場景&#xff08;如車牌、身份證&#xff09;輸入&#xff1a;圖像格式&#xff08;JPG/PNG&#xff…

基于Django的計算機資源爬蟲及可視化系統的設計與實現

文章目錄有需要本項目的代碼或文檔以及全部資源&#xff0c;或者部署調試可以私信博主一、項目背景二、項目目標三、系統架構與技術選型四、系統功能模塊五、應用場景與價值六、項目特色與創新點七、總結每文一語有需要本項目的代碼或文檔以及全部資源&#xff0c;或者部署調試…

SH3001六軸傳感器應用(二)(IIC驅動開發)

一、前言我這邊使用的開發板原本已經做好了該sensor的驅動&#xff0c;但是使用過程中發現&#xff0c;原始驅動sensor是通過事件的方式上報的&#xff0c;加速度和陀螺儀數據并不同步&#xff0c;不滿足使用要求&#xff0c;只有重新寫一個iic的驅動&#xff0c;進行sensor數據…

面試題:基礎的sql命令

基礎的 SQL 命令主要用于對數據庫進行查詢、新增、修改、刪除等操作&#xff0c;可分為以下幾類&#xff1a;一、數據查詢&#xff08;SELECT&#xff09;用于從表中獲取數據&#xff0c;是最常用的命令。 基本語法&#xff1a;SELECT 列名1, 列名2... FROM 表名 WHERE 條件;示…

Leetcode-3488距離最小相等元素查詢

依舊二分&#xff0c;鏈接如下3488. 距離最小相等元素查詢 看題目是個循環數組&#xff0c;記得當時做過一道什么題也是循環數組&#xff0c;就想著直接數組復制一下&#xff0c;然后跟上一道題一樣&#xff0c;用hashmap來存儲value的值以及value對應下標的vector。 和靈神的…

C++中的關聯容器

文章目錄使用關聯容器定義關聯容器關鍵字類型的要求pair類型用作返回類型關聯容器上的操作關聯容器的迭代器關聯容器和算法添加元素刪除元素map的下標操作訪問元素無序容器對關鍵字的要求關聯容器支持高效的關鍵字查找和訪問。兩個主要的關聯容器的類型是map和set。其中map中的…

【Git】git提交代碼報錯Git: husky > pre-commit

git提交代碼報錯原因 這個問題是因為當你在終端輸入git commit -m “XXX”,提交代碼的時候,pre-commit(客戶端)鉤子&#xff0c;它會在Git鍵入提交信息前運行做代碼風格檢查。如果代碼不符合相應規則&#xff0c;則報錯&#xff0c;而它的檢測規則就是根據.git/hooks/pre-commi…

Unity開發者快速認識Unreal 的C++(六)GameMode之PlayerController

繼承關系&#xff1a;Aactor&#xff0c;INavAgentInterface <--- AController<--- PlayerController &#xff0c;PlayerController也是一個Actor,繼承了Actor的一些通用的屬性和工具函數下圖是PlayerController初始化組件的一個子階段從圖中可以得到的信息是&#xf…

Vue 3 服務端渲染(SSR)與客戶端渲染(CSR)的區別及解決方案

1. SSR與CSR的區別1.1. SSR的原理服務端渲染&#xff08;SSR&#xff09;是在服務器端將 Vue 組件渲染為 HTML 字符串&#xff0c;并將其發送給客戶端。這種方式與客戶端渲染&#xff08;CSR&#xff09;不同&#xff0c;后者是在瀏覽器中執行 JavaScript 來生成 HTML。在 SSR …

Matlab快速回顧

一1.數值 顯示 格式format style 設置eg: pi format longE;or2.清除指令clc 清除命令行窗口clear 清除工作區cls3.搜索路徑設置path(path,E:\ads\)oraddpath4.M文件用戶把要實現的命令寫在一個以.m為擴展的文件中&#xff0c;然后由matlab系統進行解讀&#xff0c;最后運行結果…

開源低代碼+AI引擎:百特搭企業級開發平臺的演進

在數字化轉型進入深水區的今天&#xff0c;企業應用開發面臨前所未有的復雜挑戰&#xff1a;既要快速響應業務需求&#xff0c;又要確保系統靈活可控&#xff1b;既要降低技術門檻&#xff0c;又要保障核心安全。傳統開發模式與單一形態的低代碼工具已難以滿足多層次需求。融合…

學習 Android(十五)NDK進階及性能優化

學習 Android&#xff08;十五&#xff09;NDK進階及性能優化 對 NDK 相關知識有了初步的了解之后&#xff0c;我們可以更加深入的去學習 NDK 相關知識&#xff0c;接下來&#xff0c;我們將按照以下步驟進行深入學習&#xff1a; 深入理解JNI調用過程和性能消耗常見 JNI 坑&am…

QT5.12.8 QTabWidget 透明樣式QSS

/* 設置QTabWidget本身 :不加也行*/ QTabWidget#aaa_tabwdt {background: transparent;border: none; /* 移除邊框可能有助于透明效果 */ }/* 標簽頁內的容器部件 :必須加&#xff0c;標簽也才會透明 */ QTabWidget#aaa_tabwdt QWidget, QTabWidget#aaa_tabwdt QFrame {backgro…

【FAQ】Script導出SharePoint 目錄文件列表并統計大小

一、只導出文件列表的方法 1) 保存腳本&#xff08;建議名&#xff1a;D:\tmp\Export-SharePoint-FileList.ps1&#xff09; <# 導出 SharePoint 指定文件夾&#xff08;含子文件夾&#xff09;的文件列表到 CSV&#xff08;不統計大小&#xff09; 前提&#xff1a;已安…

《Thinking in Java》讀書筆記---控制執行流程

就像有感知的生物一樣&#xff0c;程序必須在執行過程中控制它的世界&#xff0c;并做出選擇。在Java中&#xff0c;你要使用執行控制語句來作出選擇。一、流程控制基礎概念1.1 流程控制的重要性流程控制結構決定了程序執行的順序和邏輯分支&#xff0c;是編程語言中最基礎也是…

極驗 G-star 人才特訓營:為業務安全領域培養下一代新興力量

本文導讀 極驗為什么要啟動 G-star 實習生培養計劃&#xff1f;50多位來自多所高校的同學&#xff0c;在極驗經歷了一場怎樣的“非典型”實習&#xff1f;技術大咖親授&#xff0c;先培訓再實戰&#xff0c;極驗打造的是怎樣的人才體系&#xff1f;同學有話說&#xff1a;培養計…

攻防世界-web-csaw-mfw

一.題目分析這邊提示使用了Git&#xff0c;試著訪問.git看是否存在.git泄露瀏覽了一下&#xff0c;很多都是亂碼&#xff0c;想著用githack將git庫克隆下看一下二.操作python2 GitHack.py http://url/.git訪問了一下flag.php&#xff0c;沒啥發現&#xff0c;在看一下index.php…

202506 電子學會青少年等級考試機器人四級實際操作真題

更多內容和歷年真題請查看網站&#xff1a;【試卷中心 -----> 電子學會 ----> 機器人技術 ----> 四級】 網站鏈接 青少年軟件編程歷年真題模擬題實時更新 2025年6月 青少年等級考試機器人實操真題四級 實際操作 主題&#xff1a;感應節能燈&#xff08;四級&am…