PostgreSQL pg_stat_bgwriter 视图各个字段详解

解析 PostgreSQL pg_stat_bgwriter 各个字段:

sql 复制代码
select * from pg_stat_bgwriter;
-[ RECORD 1 ]---------+------------------------------
checkpoints_timed     | 13
checkpoints_req       | 1
checkpoint_write_time | 1
checkpoint_sync_time  | 1
buffers_checkpoint    | 0
buffers_clean         | 0
maxwritten_clean      | 0
buffers_backend       | 0
buffers_backend_fsync | 0
buffers_alloc         | 186
stats_reset           | 2025-11-01 19:03:31.207565+08

pg_stat_bgwriter 是一个非常有用的PostgreSQL系统视图,显示了后台写入进程(background writer)的统计信息,帮助了解数据库的I/O性能和检查点行为。

以下详细解析每个字段的含义:

字段解析

检查点相关

  • checkpoints_timed | 13

    • 按计划触发的检查点数量(基于checkpoint_timeout参数)
  • checkpoints_req | 1

    • 按需触发的检查点数量(通常因为WAL日志快满了)
  • checkpoint_write_time | 1

    • 检查点期间花费在写入数据的总时间(毫秒)
  • checkpoint_sync_time | 1

    • 检查点期间花费在同步数据到磁盘的总时间(毫秒)

缓冲区相关

  • buffers_checkpoint | 0

    • 由检查点进程写入的缓冲区数量
  • buffers_clean | 0

    • 由后台写入进程清理的缓冲区数量
  • maxwritten_clean | 0

    • 后台写入进程因达到bgwriter_lru_maxpages限制而停止清理操作的次数
  • buffers_backend | 0

    • 由后端进程直接写入的缓冲区数量
  • buffers_backend_fsync | 0

    • 后端进程被迫自己执行fsync操作的次数
  • buffers_alloc | 186

    • 分配的缓冲区总数

统计重置

  • stats_reset | 2025-11-01 19:03:31.207565+08
    • 上次重置统计信息的时间戳

性能分析要点

从你的数据可以看出:

  1. 检查点行为良好

    • 大部分检查点是按计划触发的(13次),只有1次是按需触发
    • 说明WAL日志配置合理,没有频繁的紧急检查点
  2. I/O负载较轻

    • 所有缓冲区计数都为0或很低
    • 检查点写入和同步时间都很短(1毫秒)
  3. 内存使用正常

    • 分配了186个缓冲区,属于正常范围

监控建议

sql 复制代码
-- 查看检查点比例
SELECT 
  checkpoints_timed,
  checkpoints_req,
  round(100 * checkpoints_req::numeric / (checkpoints_timed + checkpoints_req), 2) 
    as req_checkpoint_pct
FROM pg_stat_bgwriter;

这个视图对于调优bgwriter_delaybgwriter_lru_maxpages等参数非常有帮助。

相关推荐
倔强的石头_9 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
chlk12315 小时前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑15 小时前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件16 小时前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
xy1230616 小时前
OpenStack Train 部署实战(三)控制节点--keystone服务
centos·openstack
深紫色的三北六号1 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash1 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
哈基咪怎么可能是AI2 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行2 天前
Linux和window共享文件夹
linux