system_stats

PostgreSQL 的系统统计函数

概览

扩展包名版本分类许可证语言
system_stats4.0STATPostgreSQLC
ID扩展名BinLibLoadCreateTrustReloc模式
6420system_stats-
相关扩展pgnodemx pg_proctab pgmeminfo pgfincore pg_wait_sampling pg_buffercache pg_background pg_cooldown

版本

类型仓库版本PG 大版本包名依赖
EXTMIXED4.01817161514system_stats-
RPMPGDG4.01817161514system_stats_$v-
DEBPIGSTY4.01817161514postgresql-$v-system-stats-
OS / PGPG18PG17PG16PG15PG14
el8.x86_64
el8.aarch64
el9.x86_64
el9.aarch64
el10.x86_64
el10.aarch64
d12.x86_64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
d12.aarch64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
d13.x86_64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
d13.aarch64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
u22.x86_64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
u22.aarch64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
u24.x86_64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
u24.aarch64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
u26.x86_64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
u26.aarch64
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0
PIGSTY 4.0

构建

您可以使用 pig build 命令构建 system_stats 扩展的 DEB 包:

pig build pkg system_stats         # 构建 DEB 包

安装

您可以直接安装 system_stats 扩展包的预置二进制包,首先确保 PGDGPIGSTY 仓库已经添加并启用:

pig repo add pgsql -u          # 添加仓库并更新缓存

使用 pig 或者是 apt/yum/dnf 安装扩展:

pig install system_stats;          # 当前活跃 PG 版本安装
pig ext install -y system_stats -v 18  # PG 18
pig ext install -y system_stats -v 17  # PG 17
pig ext install -y system_stats -v 16  # PG 16
pig ext install -y system_stats -v 15  # PG 15
pig ext install -y system_stats -v 14  # PG 14
dnf install -y system_stats_18       # PG 18
dnf install -y system_stats_17       # PG 17
dnf install -y system_stats_16       # PG 16
dnf install -y system_stats_15       # PG 15
dnf install -y system_stats_14       # PG 14
apt install -y postgresql-18-system-stats   # PG 18
apt install -y postgresql-17-system-stats   # PG 17
apt install -y postgresql-16-system-stats   # PG 16
apt install -y postgresql-15-system-stats   # PG 15
apt install -y postgresql-14-system-stats   # PG 14

创建扩展

CREATE EXTENSION system_stats;

用法

来源:READMERelease v4.0SQL install script

system_stats 通过 SQL 函数暴露操作系统指标。它支持 Linux、macOS 与 Windows,对于当前平台无意义的字段会返回 NULL

主要函数

CREATE EXTENSION system_stats;

SELECT * FROM pg_sys_os_info();
SELECT * FROM pg_sys_cpu_info();
SELECT * FROM pg_sys_cpu_usage_info();
SELECT * FROM pg_sys_memory_info();
SELECT * FROM pg_sys_io_analysis_info();
SELECT * FROM pg_sys_disk_info();
SELECT * FROM pg_sys_load_avg_info();
SELECT * FROM pg_sys_process_info();
SELECT * FROM pg_sys_network_info();
SELECT * FROM pg_sys_cpu_memory_by_process();

这些函数覆盖 OS identity、CPU inventory 与 usage、memory、block-device I/O、disks、load average、process counts、network interfaces,以及 per-process CPU 与 memory usage。

访问控制

GRANT monitor_system_stats TO nagios;
GRANT EXECUTE ON FUNCTION pg_sys_os_info() TO pg_monitor;
  • 该扩展会创建 monitor_system_stats role,并将内置函数的执行权限授予该 role。
  • 所有函数都会从 PUBLIC 撤销。

注意事项

  • 删除扩展时不会自动删除 monitor_system_stats role。
  • 在 macOS 上,系统无法暴露其他用户拥有进程的完整 per-process 细节;这些行可能只包含 PID 与进程名。
  • 当前 v4.0 上游文档保持相同的用户函数族和安全模型;这次刷新主要是使名称、权限和平台说明与当前 README 和 SQL script 对齐。

最后修改 2026-05-01: update extension data (e399d22)