| From: | Michael Paquier <michael(at)paquier(dot)xyz> | 
|---|---|
| To: | pgsql-committers(at)lists(dot)postgresql(dot)org | 
| Subject: | pgsql: Fix correctness issue with computation of FPI size in WAL stats | 
| Date: | 2025-10-29 00:14:10 | 
| Message-ID: | E1vDtpK-003zyI-1a@gemulon.postgresql.org | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-committers | 
Fix correctness issue with computation of FPI size in WAL stats
XLogRecordAssemble() may be called multiple times before inserting a
record in XLogInsertRecord(), and the amount of FPIs generated inside
a record whose insertion is attempted multiple times may vary.
The logic added in f9a09aa29520 touched directly pgWalUsage in
XLogRecordAssemble(), meaning that it could be possible for pgWalUsage
to be incremented multiple times for a single record.  This commit
changes the code to use the same logic as the number of FPIs added to a
record, where XLogRecordAssemble() returns this information and feeds it
to XLogInsertRecord(), updating pgWalUsage only when a record is
inserted.
Reported-by: Shinya Kato <shinya11(dot)kato(at)gmail(dot)com>
Discussion: https://postgr.es/m/CAOzEurSiSr+rusd0GzVy8Bt30QwLTK=ugVMnF6=5WhsSrukvvw@mail.gmail.com
Branch
------
master
Details
-------
https://git.postgresql.org/pg/commitdiff/d3111cb753e81a64c1a4417ed6de98a90a04432a
Modified Files
--------------
src/backend/access/transam/xlog.c       |  2 ++
src/backend/access/transam/xloginsert.c | 13 ++++++++-----
src/include/access/xlog.h               |  1 +
3 files changed, 11 insertions(+), 5 deletions(-)
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Michael Paquier | 2025-10-29 00:58:47 | pgsql: Simplify newline handling in libpq TAP test | 
| Previous Message | Nathan Bossart | 2025-10-28 19:09:28 | pgsql: Add psql PROMPT variable for search_path. |