]> granicus.if.org Git - postgresql/commitdiff
Count locked pages that don't need vacuuming as scanned.
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>
Mon, 18 Nov 2013 07:51:09 +0000 (09:51 +0200)
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>
Mon, 18 Nov 2013 07:51:09 +0000 (09:51 +0200)
Previously, if VACUUM skipped vacuuming a page because it's pinned, it
didn't count that page as scanned. However, that meant that relfrozenxid
was not bumped up either, which prevented anti-wraparound vacuum from
doing its job.

Report by Миша Тюрин, analysis and patch by Sergey Burladyn and Jeff Janes.
Backpatch to 9.2, where the skip-locked-pages behavior was introduced.

src/backend/commands/vacuumlazy.c

index e1d6d1c9e6199cd5e515d6982190d54cfca0d04a..6778c7d58fa5eddac99e8d39fd71431509552183 100644 (file)
@@ -602,6 +602,7 @@ lazy_scan_heap(Relation onerel, LVRelStats *vacrelstats,
                        if (!lazy_check_needs_freeze(buf))
                        {
                                UnlockReleaseBuffer(buf);
+                               vacrelstats->scanned_pages++;
                                continue;
                        }
                        LockBuffer(buf, BUFFER_LOCK_UNLOCK);