您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“PostgreSQL pg_archivecleanup與如何清理archivelog”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“PostgreSQL pg_archivecleanup與如何清理archivelog”這篇文章吧。
pg_archivecleanup 和 pg_rewind 是PG 中兩個重要的功能,一個是為了清理過期的 archive log 使用的命令,另一個是你可以理解為物理級別的 wal log的搬運工。
我們先說第一個 pg_archivecleanup 命令,這個命令主要是用于使用了archive log 功能的 postgresql 但在 archive log 堆積如山的情況下,你怎么來根據某些規則,清理這些日志呢?
這里面就要使用 pg_archivecleanup 這個命令了,可以定時的來運行它,將已經移動到archivecleanup 的目錄的archivelog 根據要求開始清理。
當然我們先的說說如果不定期清理會出什么問題
1 如果不定期清理archive 如果存放archivelog 的位置無法在接受新的日志,則大量WAL日志會滯留在 wal_log 目錄中,則整體數據庫系統都會受到影響。
2 占用大量的存儲空間,存儲無效的數據
那一般來說如果沒有第三方的備份工具的情況下,怎么來通過pg_archivecleanup 來進行archivelog 的清理。
需要關注幾個點
1 清理的時,清理的WAL_LOG 是否已經是包含在最后一次的備份中,保證清理的WAL_LOG 也可以從備份文件中恢復數據庫
2 清理的時候,對于保存在非主庫的wal_log 怎么辦
一般來說,設置自動清理archive_log 可以在配置文件中添加
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
以上是“PostgreSQL pg_archivecleanup與如何清理archivelog”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。