pgsql: Ensure vacuum removes all visibly dead tuples older than OldestX

Поиск
Список
Период
Сортировка
От Melanie Plageman
Тема pgsql: Ensure vacuum removes all visibly dead tuples older than OldestX
Дата
Msg-id E1sUqGT-000HlE-6j@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Ensure vacuum removes all visibly dead tuples older than OldestXmin

If vacuum fails to remove a tuple with xmax older than
VacuumCutoffs->OldestXmin and younger than GlobalVisState->maybe_needed,
it will loop infinitely in lazy_scan_prune(), which compares tuples'
visibility information to OldestXmin.

Starting in version 14, which uses GlobalVisState for visibility testing
during pruning, it is possible for GlobalVisState->maybe_needed to
precede OldestXmin if maybe_needed is forced to go backward while vacuum
is running. This can happen if a disconnected standby with a running
transaction older than VacuumCutoffs->OldestXmin reconnects to the
primary after vacuum initially calculates GlobalVisState and OldestXmin.

Fix this by having vacuum always remove tuples older than OldestXmin
during pruning. This is okay because the standby won't replay the tuple
removal until the tuple is removable. Thus, the worst that can happen is
a recovery conflict.

Fixes BUG# 17257

Back-patched in versions 14-17

Author: Melanie Plageman

Reviewed-by: Noah Misch, Peter Geoghegan, Robert Haas, Andres Freund, and Heikki Linnakangas
Discussion: https://postgr.es/m/CAAKRu_Y_NJzF4-8gzTTeaOuUL3CcGoXPjXcAHbTTygT8AyVqag%40mail.gmail.com

Branch
------
REL_16_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/06bf404cd07bd82f08a3000d5977080f945e70ca

Modified Files
--------------
src/backend/access/heap/pruneheap.c  | 49 +++++++++++++++++++++++++++---------
src/backend/access/heap/vacuumlazy.c |  3 ++-
src/include/access/heapam.h          |  1 +
3 files changed, 40 insertions(+), 13 deletions(-)


В списке pgsql-committers по дате отправления:

Предыдущее
От: Heikki Linnakangas
Дата:
Сообщение: pgsql: Move resowner from common JitContext to LLVM specific
Следующее
От: Nathan Bossart
Дата:
Сообщение: pgsql: Add overflow checks to money type.