public inbox for [email protected]  
help / color / mirror / Atom feed
From: Michael Paquier <[email protected]>
To: [email protected]
Subject: pgsql: Add WAL data to backend statistics
Date: Tue, 11 Mar 2025 00:05:42 +0000
Message-ID: <[email protected]> (raw)

Add WAL data to backend statistics

This commit adds per-backend WAL statistics, providing the same
information as pg_stat_wal, except that it is now possible to know how
much WAL activity is happening in each backend rather than an overall
aggregate of all the activity.  Like pg_stat_wal, the implementation
relies on pgWalUsage, tracking the difference of activity between two
reports to pgstats.

This data can be retrieved with a new system function called
pg_stat_get_backend_wal(), that returns one tuple based on the PID
provided in input.  Like pg_stat_get_backend_io(), this is useful when
joined with pg_stat_activity to get a live picture of the WAL generated
for each running backend, showing how the activity is [un]balanced.

pgstat_flush_backend() gains a new flag value, able to control the flush
of the WAL stats.

This commit relies mostly on the infrastructure provided by
9aea73fc61d4, that has introduced backend statistics.

Bump catalog version.  A bump of PGSTAT_FILE_FORMAT_ID is not required,
as backend stats do not persist on disk.

Author: Bertrand Drouvot <[email protected]>
Reviewed-by: Michael Paquier <[email protected]>
Reviewed-by: Nazir Bilal Yavuz <[email protected]>
Reviewed-by: Xuneng Zhou <[email protected]>
Discussion: https://postgr.es/m/Z3zqc4o09dM/[email protected]

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/76def4cdd7c2b32d19e950a160f834392ea51744

Modified Files
--------------
doc/src/sgml/monitoring.sgml                | 19 +++++++
src/backend/utils/activity/pgstat_backend.c | 87 ++++++++++++++++++++++++++++-
src/backend/utils/activity/pgstat_wal.c     |  1 +
src/backend/utils/adt/pgstatfuncs.c         | 26 ++++++++-
src/include/catalog/catversion.h            |  2 +-
src/include/catalog/pg_proc.dat             |  7 +++
src/include/pgstat.h                        | 41 ++++++++------
src/include/utils/pgstat_internal.h         |  3 +-
src/test/regress/expected/stats.out         | 17 +++++-
src/test/regress/sql/stats.sql              |  9 ++-
10 files changed, 185 insertions(+), 27 deletions(-)



reply

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Reply to all the recipients using the --to and --cc options:
  reply via email

  To: [email protected]
  Cc: [email protected], [email protected]
  Subject: Re: pgsql: Add WAL data to backend statistics
  In-Reply-To: <[email protected]>

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

This inbox is served by agora; see mirroring instructions
for how to clone and mirror all data and code used for this inbox