Postgresql清理WAL日志
WAL
是Write Ahead Log
的简写,和oracle的redo日志类似,存放在$PGDATA/pg_xlog
中,10
版本以后在$PGDATA/pg_wal
目录.
1、如果开启了归档,在目录archive_status
下会有一些文件,以ready
结尾的,表示可以归档但还没有归档,done
结尾的表示已经归档。
和WAL
日志数量相关的几个参数:
2、如果没有开启归档的情况下:
不超过以下两个公式计算得出的个数:
(2 + checkpoint_completion_target) * checkpoint_segments + 1
- 或者
checkpoint_segments + wal_keep_segments + 1
9.5以后,如果超过了
max_wal_size
,那么就会删除不需要的wal
.如果开启了归档,那么归档成功了,才会被清除,所以这里注意一下,
如果你开启了归档,但是归档命令是失效的,那么wal目录会一直增长,不会自动删除WAL,会使得此目录被撑爆
。3. 什么情况下回自动清理wal
做检查点的时候;
数据库启动的时候,或者修改了相关参数后重启数据库。
触发检查点的情况:
从前一个检查点发生过后的时间超过checkpoint_timeout设置的间隔(默认间隔为300秒(5分钟))。
在版本9.4或更早版本中,自上一个检查点以来,超过使用checkpoint_segments(默认数量为3)设置的WAL段文件数量。
在9.5或更高版本中,pg_xlog(版本10或更高版本,pg_wal)中WAL段文件的总大小已超过参数max_wal_size的值(默认值为1GB(64个文件))。
PostgreSQL服务在smart和fast模式下停止。
手动执行checkpoint.
3. 如何手动清理wal
可以通过缩小以上涉及到的函数减少
wal segment
的数量,也可以手动删除,如下:
这里表示
16/79FF54E8
检查点已经执行,已经包含在00000001000000160000001E
日志文件中,那么这个日志之前的日志是可以清理的。可以手动使用系统命令
rm
清理,也可以使用pg_archivecleanup
清理
比如:
或者直接删除指定前几天日志
find ./ -mtime +10 -exec rm -f {} \; #删除10天以前的所有日志。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具