好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 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流日志誤刪處理(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的恢復。不過會丟失一些事務。恢復命令也很簡單如下:

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

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

參考:pg_resetxlog官方文檔

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

您可能感興趣的文章:
  • Postgresql排序與limit組合場景性能極限優化詳解
  • 解決postgresql無法遠程訪問的情況
  • 淺談Postgresql默認端口5432你所不知道的一點
  • postgresql修改完端口后直接psql連接數據庫報錯的解決
  • postgresql 實現啟動、狀態查看、關閉
  • postgresql連續歸檔及時間點恢復的操作
  • 解決PostgreSQL日志信息占用磁盤過大的問題
  • 關于PostgreSQL 行排序的實例解析

標簽:烏海 珠海 衡陽 株洲 來賓 晉城 蚌埠 錦州

巨人網絡通訊聲明:本文標題《PostgreSQL pg_archivecleanup與清理archivelog的操作》,本文關鍵詞  PostgreSQL,archivecleanup,與,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL pg_archivecleanup與清理archivelog的操作》相關的同類信息!
  • 本頁收集關于PostgreSQL pg_archivecleanup與清理archivelog的操作的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 午夜A级理论片915影院| 蜜桃成熟时在线| 亚洲第一成人在线| 日韩精品AV一区二区三区无码视频| 熟睡侵犯h| 翁含着我的奶边摸边做小视频| 只穿裙子无内裤的小说| 日韩亚洲成a人片在线观看| 国产真实伦对白视频全集| 原創戲劇親愛的亞當的播出时间| 小可的奶水txt正版全文| 国内精品久久影院| 恶人想要抢救一下漫画免费在哪看| 欧美综合图片一区二区三区| 嗯~用力啊~嗯~c我~主人视频| 漂亮阿性教育在线观看| 一个人看的视频在线中文动漫| 国产一级a毛一级a看免费人交| 亚亚洲精品黑人巨大在线播放| 国产丝袜大长腿精品丝袜美女图片 | 久久国产精品99久久久久久| 老师?开腿让我爽一夜| 羽月希哺乳期授乳丿| 131美女爱做免费高清视频| 不扣纽扣扣的女孩免费观看| 91色琪琪电影亚洲精品久久| 97色伦在线观看免费高清小说| 国模啪啪一区二区三区| 精品久久免费视频| 我的扶她闺蜜3p| 91精产品一区一区三区40p| 娇喘(师生,出轨)| 蚂蚁三级在线网站| 用妹妹的身体做实验纸桃子移植| 网禁??拗女稀缺1366| 91在线无码精品秘?黑桃| 久久福利一区二区三区| 免费观看特黄60分钟大片 | 国产理论片午午午伦夜理片2021 | 亚洲精品午夜| 男同boy|