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

主頁 > 知識庫 > Postgresql 如何清理WAL日志

Postgresql 如何清理WAL日志

熱門標簽:打電話智能電銷機器人授權 重慶自動外呼系統定制 合肥公司外呼系統運營商 地圖標注和圖片名稱的區別 外呼調研系統 辦公外呼電話系統 海豐有多少商家沒有地圖標注 美容工作室地圖標注 漯河外呼電話系統

WAL是Write Ahead Log的簡寫,和oracle的redo日志類似,存放在$PGDATA/pg_xlog中,10版本以后在$PGDATA/pg_wal目錄.

如果開啟了歸檔,在目錄archive_status下會有一些文件,以ready結尾的,表示可以歸檔但還沒有歸檔,done結尾的表示已經歸檔。

和WAL日志數量相關的幾個參數:

wal_keep_segments = 300     # in logfile segments, 16MB each; 0 disables 
checkpoint_completion_target = 0.5   # checkpoint target duration, 0.0 - 1.0 
checkpoint_segments = 2048       # in logfile segments, min 1, 16MB each 
#9.5以后checkpoint_segments不再使用,要參考設置以下兩個參數
#max_wal_size = 1GB #最大不超過這個值
#min_wal_size = 80MB #最小保留這個值

如果沒有開啟歸檔的情況下:

不超過以下兩個公式計算得出的個數

(2 + checkpoint_completion_target) * checkpoint_segments + 1 或者checkpoint_segments + wal_keep_segments + 1

9.5以后,如果超過了max_wal_size,那么就會刪除不需要的wal.

如果開啟了歸檔,那么歸檔成功了,才會被清除,所以這里注意一下,如果你開啟了歸檔,但是歸檔命令是失效的,那么wal目錄會一直增長,不會自動刪除WAL,會使得此目錄被撐爆。

什么情況下回自動清理wal

1.做檢查點的時候

2.數據庫啟動的時候,或者修改了相關參數后重啟數據庫。

觸發檢查點的情況:

1.從前一個檢查點發生過后的時間超過checkpoint_timeout設置的間隔(默認間隔為300秒(5分鐘))。

2.在版本9.4或更早版本中,自上一個檢查點以來,超過使用checkpoint_segments(默認數量為3)設置的WAL段文件數量。

3.在9.5或更高版本中,pg_xlog(版本10或更高版本,pg_wal)中WAL段文件的總大小已超過參數max_wal_size的值(默認值為1GB(64個文件))。

4.PostgreSQL服務在smart和fast模式下停止。

5.手動執行checkpoint.

如何手動清理wal

可以通過縮小以上涉及到的函數減少wal segment的數量,也可以手動刪除,如下:

pg_controldata
Latest checkpoint location: 16/79FF5520
Latest checkpoint's REDO location: 16/79FF54E8
Latest checkpoint's REDO WAL file: 00000001000000160000001E

這里表示16/79FF54E8檢查點已經執行,已經包含在00000001000000160000001E日志文件中,那么這個日志之前的日志是可以清理的。

可以手動使用系統命令rm清理

也可以使用pg_archivecleanup清理

比如:

查看日志
ll
total 833M
-rw------- 1 postgres postgres 64M Aug 29 11:10 00000001000000160000001E
-rw------- 1 postgres postgres 64M Jul 16 11:24 00000001000000160000001F
-rw------- 1 postgres postgres 64M Jul 16 11:24 000000010000001600000020
-rw------- 1 postgres postgres 64M Jul 16 11:25 000000010000001600000021
-rw------- 1 postgres postgres 64M Jul 16 11:25 000000010000001600000022
-rw------- 1 postgres postgres 64M Jul 16 11:26 000000010000001600000023
-rw------- 1 postgres postgres 64M Jul 16 11:24 000000010000001600000024
-rw------- 1 postgres postgres 64M Jul 16 11:24 000000010000001600000025
-rw------- 1 postgres postgres 64M Jul 16 11:26 000000010000001600000026
-rw------- 1 postgres postgres 64M Jul 16 11:40 000000010000001600000027
-rw------- 1 postgres postgres 64M Jul 16 11:40 000000010000001600000028
-rw------- 1 postgres postgres 64M Jul 16 11:51 000000010000001600000029
-rw------- 1 postgres postgres 64M Jul 16 11:40 00000001000000160000002A
drwx------ 2 postgres postgres 4.0K Jun 18 10:15 archive_status
保留000000010000001600000027之后的日志
 pg_archivecleanup /opt/pgdata11.3/pg_root/pg_wal/ 000000010000001600000027
 
 再次查看驗證
 ls
000000010000001600000027 000000010000001600000028 000000010000001600000029 00000001000000160000002A archive_status

補充:Postgresql 數據庫設置備份以及簡單清理磁盤空間和wal日志的方法

1. 最近想簡單的進行數據庫的備份工作, 因為現在數據庫主要是用的pg數據庫 , 所以想到用文本的方式進行, 有清理了一下日志表的數據 這里一起記錄一下.

先記錄一下查看比較大的表的信息.

從網上找了下資料, 使用子查詢的方式來查詢表信息.

SELECT
  table_name,
  pg_size_pretty(table_size) AS table_size,
  pg_size_pretty(indexes_size) AS indexes_size,
  pg_size_pretty(total_size) AS total_size
FROM (
  SELECT
    table_name,
    pg_table_size(table_name) AS table_size,
    pg_indexes_size(table_name) AS indexes_size,
    pg_total_relation_size(table_name) AS total_size
  FROM (
    SELECT ('"' || table_schema || '"."' || table_name || '"') AS table_name
    FROM information_schema.tables
  ) AS all_tables
  ORDER BY total_size DESC
) AS pretty_sizes;

找出來最大的表信息之后, 需要使用

truncate table 的方式能夠直接清理空間不然空間還是占用著的.

truncate table **** 

或者是在數據庫的 /data/base 目錄下面也能夠看到響應的表信息

2. 整理pg_wal 文件內的信息

wal 是 write ahead log 的意思 里面跟oracle的redo內容類似, 有時候文件會比較多需要清理一下.

方法

su - postgres
cd /usr/lib/yourpgbinpath
./pg_resetwal {PGDATA}
執行清理

3. 執行備份恢復的方式

備份 
tar -czvf /pgdata.tar.gz /pgdatapath
恢復
tar -zxvf /pgdata.tar.gz / 
恢復即可,

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

您可能感興趣的文章:
  • PostgreSQL 打印日志信息所在的源文件和行數的實例
  • postgresql 切換 log、xlog日志的實現
  • 解決PostgreSQL日志信息占用磁盤過大的問題
  • PostgreSQL歸檔配置及自動清理歸檔日志的操作
  • 關于PostgreSQL錯誤日志與慢查詢日志收集
  • Postgresql的日志配置教程詳解
  • PostgreSQL 日志文件的所在位置

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

巨人網絡通訊聲明:本文標題《Postgresql 如何清理WAL日志》,本文關鍵詞  Postgresql,如何,清理,WAL,日志,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Postgresql 如何清理WAL日志》相關的同類信息!
  • 本頁收集關于Postgresql 如何清理WAL日志的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: swag国产精品一区二区| 美女被????到流水羞羞| 国产大乳喷奶水在线看| japanesejavahdfeesexhd| 黑巨根| 温碧霞三级无删减视频| 两个人看的www片免费中文| 免费精品视频| 高冷双性受被各种play| tes-369友田真希在线看| 小东西几天不见水又变多怎么回事| 妇女被猛烈进入在线播放| 嗯啊好爽视频| 大乳喷奶水榨乳在线日本| 天天综合,91综合永久| 国产香港乡下三级全黄在线观看| 欧美人与黑人交| 日本电车痴汉电影| 精品夜夜澡人妻无码AV| 99热精品国产免费| 女人特写大尺度ass| 午夜爽爽爽男女免费观看| 啊灬啊灬啊灬快灬深视频日本| 国产伦理女村支书| 国产精品无码ThePorn| 国产线观看A片免费看老狼| 2021年的三片日剧免费| 99精品视频| 少妇做爰特黄A片免费看| 亚洲综合憿情五月色丁香色婷婷 | o女人裸体又黄??A片小说| 国模少妇一区二区三区咪咕| 日韩在线1| 免费观看日本| 免费??成人??用黄上黄两年半| 中文字幕の友人北条麻妃| 公交车上解我胸罩玩我下面| 成人短视频app| 超级乱淫伦小说一女多男| 1204基地手机看懂的旧版| 亚洲AV无码秘?蜜桃希岛爱理|