亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PostgreSQL pg_archivecleanup與清理archivelog的操作

 更新時間:2021年01月11日 10:48:49   作者:Austindatabases  
這篇文章主要介紹了PostgreSQL pg_archivecleanup與清理archivelog的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

pg_archivecleanup 和 pg_rewind 是PG 中兩個重要的功能,一個是為了清理過期的 archive log 使用的命令,另一個是你可以理解為物理級別的 wal log的搬運工。

我們先說第一個 pg_archivecleanup 命令,這個命令主要是用于使用了archive log 功能的 postgresql 但在 archive log 堆積如山的情況下,你怎么來根據某些規(guī)則,清理這些日志呢?

這里面就要使用 pg_archivecleanup 這個命令了,可以定時的來運行它,將已經移動到archivecleanup 的目錄的archivelog 根據要求開始清理。

當然我們先的說說如果不定期清理會出什么問題

1 如果不定期清理archive 如果存放archivelog 的位置無法在接受新的日志,則大量WAL日志會滯留在 wal_log 目錄中,則整體數據庫系統(tǒng)都會受到影響。

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流日志誤刪處理(xlog)

今天同事誤刪postgresql庫數據文件下的pg_xlog文件夾,導致所有流日志丟失,數據庫無法啟動,觀察警告日志:

2018-03-12 18:45:54 CST LOG: database system shutdown was interrupted; last known up at 2018-03-12 17:48:27 CST
2018-03-12 18:45:54 CST LOG: could not open file "pg_xlog/000000010000001400000060" (log file 20, segment 96): No such file or directory
2018-03-12 18:45:54 CST LOG: invalid primary checkpoint record
2018-03-12 18:45:54 CST LOG: could not open file "pg_xlog/000000010000001400000060" (log file 20, segment 96): No such file or directory
2018-03-12 18:45:54 CST LOG: invalid secondary checkpoint record
2018-03-12 18:45:54 CST PANIC: could not locate a valid checkpoint record
2018-03-12 18:45:54 CST LOG: startup process (PID 32680) was terminated by signal 6: Aborted
2018-03-12 18:45:54 CST LOG: aborting startup due to startup process failure

用postgresql自帶的pg_resetxlog工具可以跳過對WAL log的恢復。不過會丟失一些事務?;謴兔钜埠芎唵稳缦拢?/p>

pg_resetxlog -f /var/lib/pgsql/9.6/data

然后啟動postgrsql ,數據庫就可正常進入

參考:pg_resetxlog官方文檔

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關文章

  • PostgreSQL教程(十一):服務器配置

    PostgreSQL教程(十一):服務器配置

    這篇文章主要介紹了PostgreSQL教程(十一):服務器配置,本文講解了服務器進程的啟動和關閉、服務器配置、內存相關的參數配置等內容,需要的朋友可以參考下
    2015-05-05
  • PostgreSQL導出數據庫表(或序列)的結構和數據實例代碼

    PostgreSQL導出數據庫表(或序列)的結構和數據實例代碼

    這篇文章主要給大家介紹了關于PostgreSQL導出數據庫表(或序列)的結構和數據的相關資料,你可以使用pg_dump命令來導出PostgreSQL數據庫中的表結構和數據,需要的朋友可以參考下
    2023-10-10
  • 詳解如何在Ubuntu?18.04上安裝和使用PostgreSQL

    詳解如何在Ubuntu?18.04上安裝和使用PostgreSQL

    關系數據庫管理系統(tǒng)是許多網站和應用程序的關鍵組件,它們提供了一種結構化的方式來存儲、組織和訪問信息,本文演示了如何在?Ubuntu?18.04?VPS?實例上安裝?Postgres,并提供了基本數據庫管理的說明,需要的朋友可以參考下
    2024-07-07
  • Postgresql自定義函數詳解

    Postgresql自定義函數詳解

    這篇文章主要介紹了Postgresql自定義函數詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • PostgreSQL Sequence序列的使用詳解

    PostgreSQL Sequence序列的使用詳解

    這篇文章主要介紹了PostgreSQL Sequence序列的使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • PostgreSQL教程(三):表的繼承和分區(qū)表詳解

    PostgreSQL教程(三):表的繼承和分區(qū)表詳解

    這篇文章主要介紹了PostgreSQL教程(三):表的繼承和分區(qū)表詳解,本文講解了多表繼承、 繼承和權限、什么是分區(qū)表、分區(qū)表實現、分區(qū)和約束排除等內容,需要的朋友可以參考下
    2015-05-05
  • 使用python-slim鏡像遇到無法使用PostgreSQL的問題及解決方法

    使用python-slim鏡像遇到無法使用PostgreSQL的問題及解決方法

    這篇文章主要介紹了使用python-slim鏡像遇到無法使用PostgreSQL的問題及解決方法,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • PostgreSQL 查找當前數據庫的所有表操作

    PostgreSQL 查找當前數據庫的所有表操作

    這篇文章主要介紹了PostgreSQL 查找當前數據庫的所有表操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • PGSQL 實現查詢今天,昨天的數據,一個月之內的數據

    PGSQL 實現查詢今天,昨天的數據,一個月之內的數據

    這篇文章主要介紹了PGSQL 實現查詢今天,昨天的數據,一個月之內的數據,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL使用jsonb進行數組增刪改查的操作詳解

    PostgreSQL使用jsonb進行數組增刪改查的操作詳解

    有時候我們需要使用PostgreSQL這種結構化數據庫來存儲一些非結構化數據,PostgreSQL恰好又提供了json這種數據類型,這里我們來簡單介紹使用jsonb的一些常見操作,需要的朋友可以參考下
    2024-03-03

最新評論