Re: BUG #17257: (auto)vacuum hangs within lazy_scan_prune()
От | Peter Geoghegan |
---|---|
Тема | Re: BUG #17257: (auto)vacuum hangs within lazy_scan_prune() |
Дата | |
Msg-id | CAH2-Wz=HT+zHGyQ5bykPEh20KQWnS4uZS_uupxrTrtf-Wt886A@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: BUG #17257: (auto)vacuum hangs within lazy_scan_prune() (Peter Geoghegan <pg@bowt.ie>) |
Ответы |
Re: BUG #17257: (auto)vacuum hangs within lazy_scan_prune()
|
Список | pgsql-bugs |
On Sat, Jan 6, 2024 at 1:30 PM Peter Geoghegan <pg@bowt.ie> wrote: > On Sat, Jan 6, 2024 at 12:24 PM Noah Misch <noah@leadboat.com> wrote: > > Fair enough. While I agree there's a decent chance back-patching would be > > okay, I think there's also a decent chance that 1ccc1e05ae creates the problem > > Matthias theorized. Something like: we update relfrozenxid based on > > OldestXmin, even though GlobalVisState caused us to retain a tuple older than > > OldestXmin. Then relfrozenxid disagrees with table contents. > > Either every relevant code path has the same OldestXmin to work off > of, or the whole NewRelfrozenXid/relfrozenxid-tracking thing can't be > expected to work as designed. I find it a bit odd that > pruneheap.c/GlobalVisState has no direct understanding of this > dependency (none that I can discern, at least). What do you think of the idea of adding a defensive "can't happen" error to lazy_scan_prune() that will catch DEAD or RECENTLY_DEAD tuples with storage that still contain an xmax < OldestXmin? This probably won't catch every possible problem, but I suspect it'll work well enough. -- Peter Geoghegan
В списке pgsql-bugs по дате отправления: