pgsql: Use the newest to-be-frozen xid as the conflict horizon for free - Mailing list pgsql-committers

From Melanie Plageman
Subject pgsql: Use the newest to-be-frozen xid as the conflict horizon for free
Date
Msg-id E1w02jB-003M5p-2U@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Use the newest to-be-frozen xid as the conflict horizon for freezing

Previously WAL records that froze tuples used OldestXmin as the snapshot
conflict horizon, or the visibility cutoff if the page would become
all-frozen. Both are newer than (or equal to) the newst XID actually
frozen on the page.

Track the newest XID that will be frozen and use that as the snapshot
conflict horizon instead. This yields an older horizon resulting in
fewer query cancellations on standbys.

Author: Melanie Plageman <melanieplageman@gmail.com>
Reviewed-by: Peter Geoghegan <pg@bowt.ie>
Discussion: https://postgr.es/m/CAAKRu_bbaUV8OUjAfVa_iALgKnTSfB4gO3jnkfpcFgrxEpSGJQ%40mail.gmail.com

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/c2a23dcf9e3af1c80a99b4ee43f0885eb6894e3a

Modified Files
--------------
src/backend/access/heap/heapam.c    | 14 ++++++++++++++
src/backend/access/heap/pruneheap.c | 36 +++++++++++-------------------------
src/include/access/heapam.h         | 12 ++++++++++++
3 files changed, 37 insertions(+), 25 deletions(-)


pgsql-committers by date:

Previous
From: Álvaro Herrera
Date:
Subject: pgsql: Introduce the REPACK command
Next
From: Heikki Linnakangas
Date:
Subject: pgsql: Don't clear pendingRecoveryConflicts at end of transaction