pgsql: Ignore invalidated slots while computing oldest catalog Xmin

Поиск
Список
Период
Сортировка
От Alvaro Herrera
Тема pgsql: Ignore invalidated slots while computing oldest catalog Xmin
Дата
Msg-id E1oxQ1Q-000L9g-Ue@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Ignore invalidated slots while computing oldest catalog Xmin

Once a logical slot has acquired a catalog_xmin, it doesn't let go of
it, even when invalidated by exceeding the max_slot_wal_keep_size, which
means that dead catalog tuples are not removed by vacuum anymore since
the point is invalidated, until the slot is dropped.  This could be
catastrophic if catalog churn is high.

Change the computation of Xmin to ignore invalidated slots,
to prevent dead rows from accumulating.

Backpatch to 13, where slot invalidation appeared.

Author: Sirisha Chamarthi <sirichamarthi22@gmail.com>
Reviewed-by: Ashutosh Bapat <ashutosh.bapat.oss@gmail.com>
Discussion: https://postgr.es/m/CAKrAKeUEDeqquN9vwzNeG-CN8wuVsfRYbeOUV9qKO_RHok=j+g@mail.gmail.com

Branch
------
REL_15_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/1ad033df16df8d9f9e9f597ca31915266dfbdfb9

Modified Files
--------------
src/backend/replication/slot.c      | 7 +++++++
src/backend/storage/ipc/procarray.c | 3 +++
2 files changed, 10 insertions(+)


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

Предыдущее
От: Andres Freund
Дата:
Сообщение: pgsql: Add wait event for pg_usleep() in perform_spin_delay()
Следующее
От: Amit Kapila
Дата:
Сообщение: pgsql: Improve comments atop pg_get_replication_slots.