pg_stat_log
pg_stat_log : Track cumulative PostgreSQL log message statistics by backend, database, user, level, and SQLSTATE.
Overview
| ID | Extension | Package | Version | Category | License | Language |
|---|---|---|---|---|---|---|
| 6040 | pg_stat_log
|
pg_stat_log
|
0.1 |
STAT
|
PostgreSQL
|
C
|
| Attribute | Has Binary | Has Library | Need Load | Has DDL | Relocatable | Trusted |
|---|---|---|---|---|---|---|
--sLd-r
|
No
|
Yes
|
Yes
|
Yes
|
yes
|
no
|
| Relationships | |
|---|---|
| See Also | pg_stat_statements
pg_stat_monitor
pg_stat_plans
|
Packages
| Type | Repo | Version | PG Major Compatibility | Package Pattern | Dependencies |
|---|---|---|---|---|---|
| EXT | PGDG
|
0.1 |
18
17
16
15
14
|
pg_stat_log |
- |
| RPM | PGDG
|
0.1 |
18
17
16
15
14
|
pg_stat_log_$v |
- |
| DEB | PGDG
|
0.1 |
18
17
16
15
14
|
postgresql-$v-stat-log |
- |
| Linux / PG | PG18 | PG17 | PG16 | PG15 | PG14 |
|---|---|---|---|---|---|
el8.x86_64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
el8.aarch64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
el9.x86_64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
el9.aarch64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
el10.x86_64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
el10.aarch64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
d12.x86_64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
d12.aarch64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
d13.x86_64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
d13.aarch64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
u22.x86_64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
u22.aarch64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
u24.x86_64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
u24.aarch64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
u26.x86_64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
u26.aarch64
|
PGDG 0.1
|
MISS
|
MISS
|
MISS
|
MISS
|
Source
Install
Make sure PGDG repo available:
pig repo add pgdg -u # add pgdg repo and update cacheInstall this extension with pig:
pig install pg_stat_log; # install via package name, for the active PG version
pig install pg_stat_log -v 18; # install for PG 18Config this extension to shared_preload_libraries:
shared_preload_libraries = '$libdir/pg_stat_log';Create this extension with:
CREATE EXTENSION pg_stat_log;Usage
Sources: README, SQL objects, control file
pg_stat_log collects cumulative statistics about PostgreSQL log messages. It hooks into emit_log_hook and counts messages by backend type, database, user, severity, SQLSTATE, and SQLSTATE condition name.
Enable
pg_stat_log requires PostgreSQL 18 or newer and must be preloaded:
shared_preload_libraries = 'pg_stat_log'Restart PostgreSQL, then create the extension:
CREATE EXTENSION pg_stat_log;View Statistics
SELECT *
FROM pg_stat_log
ORDER BY count DESC;The view exposes backend_type, database_oid, database_name, user_oid, user_name, elevel, sqlerrcode, sqlerrcode_name, and count.
Common Queries
SELECT elevel, sqlerrcode, sqlerrcode_name, sum(count) AS total
FROM pg_stat_log
GROUP BY elevel, sqlerrcode, sqlerrcode_name
ORDER BY total DESC
LIMIT 10;
SELECT backend_type, elevel, sqlerrcode_name, count
FROM pg_stat_log
WHERE backend_type <> 'client backend'
ORDER BY count DESC;Reset And Capacity
SELECT pg_stat_log_reset();
SELECT * FROM pg_stat_log_info();pg_stat_log_info() reports max_entries, num_entries, n_dropped, and stats_reset. Increase pg_stat_log.max_entries if n_dropped grows.
Configuration
Settings include pg_stat_log.enabled, pg_stat_log.min_error_level, and pg_stat_log.max_entries.
emit_log_hook only sees messages that reach the server log. log_min_messages therefore acts as a floor for what can be counted.