From: | Bertrand Drouvot <bertranddrouvot(dot)pg(at)gmail(dot)com> |
---|---|
To: | Michael Paquier <michael(at)paquier(dot)xyz> |
Cc: | Andres Freund <andres(at)anarazel(dot)de>, pgsql-hackers(at)lists(dot)postgresql(dot)org, Nazir Bilal Yavuz <byavuz81(at)gmail(dot)com> |
Subject: | Re: per backend WAL statistics |
Date: | 2025-02-26 10:59:11 |
Message-ID: | Z77z/wzfBR4asUZ+@ip-10-97-1-34.eu-west-3.compute.internal |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
Hi,
On Wed, Feb 26, 2025 at 04:52:13PM +0900, Michael Paquier wrote:
> On Tue, Feb 25, 2025 at 03:00:35PM +0000, Bertrand Drouvot wrote:
> > That makes fully sense. Done in 0004 attached. Somehow related to that, I've
> > a patch in progress to address some of Rahila's comments ([1]) (the one related
> > to the AuxiliaryPidGetProc() call is relevant specially since a051e71e28a where
> > pgstat_tracks_backend_bktype() has been modified for B_WAL_RECEIVER, B_WAL_SUMMARIZER
> > and B_WAL_WRITER). I'll wait for 0004 to go in before sharing the patch.
>
> Applied v9-0001
I see that you removed pgstat_flush_wal() in d7cbeaf261d (instead of what 0001
was doing i.e making it static). Makes sense to me.a
> and v9-0003 as these were fine,
Thanks.
> with more
> documentation added in pgstat.h for the new WAL structure, and the
> reason why it exists.
Saw that, looks good.
> I've noticed the difference with bktype in
> v9-0004 as the WAL part does not need this information when generating
> its tuple, OK here.
Thx.
> Doing v9-0003 after v9-0002 felt a bit odd, changing twice the
> signature of pg_stat_wal_build_tuple() to adapt with the split for the
> reset timestamp.
PFA a rebase.
> - values[4] = TimestampTzGetDatum(wal_stats->stat_reset_timestamp);
> + if (wal_stats.stat_reset_timestamp != 0)
> + values[4] = TimestampTzGetDatum(wal_stats.stat_reset_timestamp);
> + else
> + nulls[4] = true;
>
> In patch v9-0002, is this nulls[4] required for the backend part?
Yup. That's what we've done in pg_stat_io_build_tuples() too (ff7c40d7fd6).
Without this we'd get "2000-01-01 00:00:00+00" in the stats_reset field of
pg_stat_get_backend_wal() and pg_stat_get_backend_io().
That was not needed for pg_stat_io and pg_stat_wal because the stats_reset field
was already non null after initdb.
Regards,
--
Bertrand Drouvot
PostgreSQL Contributors Team
RDS Open Source Databases
Amazon Web Services: https://aws.amazon.com
Attachment | Content-Type | Size |
---|---|---|
v10-0001-Extract-logic-filling-pg_stat_get_wal-s-tuple-in.patch | text/x-diff | 3.1 KB |
v10-0002-Add-the-pg_stat_get_backend_stats-helper-for-pg_.patch | text/x-diff | 4.6 KB |
v10-0003-per-backend-WAL-statistics.patch | text/x-diff | 12.3 KB |
From | Date | Subject | |
---|---|---|---|
Next Message | Maxim Orlov | 2025-02-26 11:10:33 | Re: Proposal: Limitations of palloc inside checkpointer |
Previous Message | Laurenz Albe | 2025-02-26 10:54:08 | Re: Anti join confusion |