From: | Heikki Linnakangas <heikki(dot)linnakangas(at)iki(dot)fi> |
---|---|
To: | pgsql-committers(at)lists(dot)postgresql(dot)org |
Subject: | pgsql: Fix catcache invalidation of a list entry that's being built |
Date: | 2025-01-14 13:13:05 |
Message-ID: | E1tXgjB-001Vbd-K1@gemulon.postgresql.org |
Views: | Whole Thread | Raw Message | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-committers |
Fix catcache invalidation of a list entry that's being built
If a new catalog tuple is inserted that belongs to a catcache list
entry, and cache invalidation happens while the list entry is being
built, the list entry might miss the newly inserted tuple.
To fix, change the way we detect concurrent invalidations while a
catcache entry is being built. Keep a stack of entries that are being
built, and apply cache invalidation to those entries in addition to
the real catcache entries. This is similar to the in-progress list in
relcache.c.
Back-patch to all supported versions.
Reviewed-by: Noah Misch
Discussion: https://www.postgresql.org/message-id/2234dc98-06fe-42ed-b5db-ac17384dc880@iki.fi
Branch
------
REL_15_STABLE
Details
-------
https://git.postgresql.org/pg/commitdiff/ce7c406f0f8d562e856d43a7e1feb82043f772bc
Modified Files
--------------
src/backend/utils/cache/catcache.c | 231 +++++++++++++++++++++++--------------
src/backend/utils/cache/inval.c | 2 +-
src/include/utils/catcache.h | 1 +
src/tools/pgindent/typedefs.list | 1 +
4 files changed, 148 insertions(+), 87 deletions(-)
From | Date | Subject | |
---|---|---|---|
Next Message | Dean Rasheed | 2025-01-14 13:26:17 | pgsql: psql: Add leakproof indicator to \df+, \do+, \dAo+, and \dC+ out |
Previous Message | Michael Paquier | 2025-01-14 06:28:33 | pgsql: Bump PGSTAT_FILE_FORMAT_ID |