pg_archivecleanup 和 pg_rewind 是PG 中兩個重要的功能,一個是爲了清理過時的 archive log 使用的命令,另外一個是你能夠理解爲物理級別的 wal log的搬運工。
咱們先說第一個 pg_archivecleanup 命令,這個命令主要是用於使用了archive log 功能的 postgresql 但在 archive log 堆積如山的狀況下,你怎麼來根據某些規則,清理這些日誌呢?sql
這裏面就要使用 pg_archivecleanup 這個命令了,能夠定時的來運行它,將已經移動到archivecleanup 的目錄的archivelog 根據要求開始清理。數據庫
固然咱們先的說說若是不按期清理會出什麼問題安全
1 若是不按期清理archive 若是存放archivelog 的位置沒法在接受新的日誌,則大量WAL日誌會滯留在 wal_log 目錄中,則總體數據庫系統都會受到影響。bash
2 佔用大量的存儲空間,存儲無效的數據微信
那通常來講若是沒有第三方的備份工具的狀況下,怎麼來經過pg_archivecleanup 來進行archivelog 的清理。工具
須要關注幾個點post
1 清理的時,清理的WAL_LOG 是否已是包含在最後一次的備份中,保證清理的WAL_LOG 也能夠從備份文件中恢復數據庫spa
2 清理的時候,對於保存在非主庫的wal_log 怎麼辦.net
通常來講,設置自動清理archive_log 能夠在配置文件中添加3d
archive_cleanup_command = 'pg_archivecleanup archivelocation %r'
來操做。
但通常來講這樣作好處少,弊病多,我比較喜歡寫相關的腳本,定時去運行的方式,而且能夠記錄相關的LOG 日誌等等。
能夠寫一個腳本,來輔助定時清理相關的archive_log
固然這樣的方法也是有弊端的,若是因爲備份的緣由的故障,而直接使用天數來清理會有由於沒有備份而直接將 wal_log 給清理掉,因此更加靠譜的方法是經過某些命令來得到須要截止的清理的Wal_log 名稱。
例如 備份後的
會在wal_log 裏面有backup 的標記,這說明這個WAL log 之前的數據已經備份了,若是清理這個WAL LOG 以前的log 是安全的。
000000010000000300000030.00000060.backup
使用下面的腳本能夠來更安全的清理
#!/bin/bash
ARCHIVEDIR='/pgdata/archive'
CHK_SAFE=$(find $ARCHIVEDIR -type f -mtime +3 -name '*backup' -printf '%f\n' | sort -r | head -1)
cd $ARCHIVEDIR
/usr/local/postgres/bin/pg_archivecleanup $ARCHIVEDIR $CHK_SAFE
find $ARCHIVEDIR -type f -mtime +3 -a -name '*backup' -a ! -newer $CHKPOINT -delete
本文分享自微信公衆號 - AustinDatabases(AustinDatabases)。
若有侵權,請聯繫 support@oschina.cn 刪除。
本文參與「OSC源創計劃」,歡迎正在閱讀的你也加入,一塊兒分享。