pgsql: Avoid possible crash while finishing up a heap rewrite.

Поиск
Список
Период
Сортировка
От Tom Lane
Тема pgsql: Avoid possible crash while finishing up a heap rewrite.
Дата
Msg-id E1lOitM-00064z-6o@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Avoid possible crash while finishing up a heap rewrite.

end_heap_rewrite was not careful to ensure that the target relation
is open at the smgr level before performing its final smgrimmedsync.
In ordinary cases this is no problem, because it would have been
opened earlier during the rewrite.  However a crash can be reproduced
by re-clustering an empty table with CLOBBER_CACHE_ALWAYS enabled.

Although that exact scenario does not crash in v13, I think that's
a chance result of unrelated planner changes, and the problem is
likely still reachable with other test cases.  The true proximate
cause of this failure is commit c6b92041d, which replaced a call to
heap_sync (which was careful about opening smgr) with a direct call
to smgrimmedsync.  Hence, back-patch to v13.

Amul Sul, per report from Neha Sharma; cosmetic changes
and test case by me.

Discussion: https://postgr.es/m/CANiYTQsU7yMFpQYnv=BrcRVqK_3U3mtAzAsJCaqtzsDHfsUbdQ@mail.gmail.com

Branch
------
REL_13_STABLE

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

Modified Files
--------------
src/backend/access/heap/rewriteheap.c | 6 +++++-
src/test/regress/expected/cluster.out | 5 +++++
src/test/regress/sql/cluster.sql      | 6 ++++++
3 files changed, 16 insertions(+), 1 deletion(-)


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

Предыдущее
От: Peter Eisentraut
Дата:
Сообщение: pgsql: pgcrypto: Check for error return of px_cipher_decrypt()
Следующее
От: Tom Lane
Дата:
Сообщение: pgsql: Fix psql's \connect command some more.