]> git.ipfire.org Git - thirdparty/postgresql.git/commit
amcheck: Distinguish interrupted page deletion from corruption.
authorNoah Misch <noah@leadboat.com>
Mon, 30 Oct 2023 21:46:05 +0000 (14:46 -0700)
committerNoah Misch <noah@leadboat.com>
Mon, 30 Oct 2023 21:46:09 +0000 (14:46 -0700)
commit3a205c91665fddf76e333844884354874dc8ae1b
tree05494b75071a9685eb0f92d649311c7ad2f7019d
parentf7cd7b265f6f96689a42d61f1e312554e1ff9fa8
amcheck: Distinguish interrupted page deletion from corruption.

This prevents false-positive reports about "the first child of leftmost
target page is not leftmost of its level", "block %u is not leftmost"
and "left link/right link pair".  They appeared if amcheck ran before
VACUUM cleaned things, after a cluster exited recovery between the
first-stage and second-stage WAL records of a deletion.  Back-patch to
v11 (all supported versions).

Reviewed by Peter Geoghegan.

Discussion: https://postgr.es/m/20231005025232.c7.nmisch@google.com
contrib/amcheck/t/005_pitr.pl [new file with mode: 0644]
contrib/amcheck/verify_nbtree.c