Re: eliminate xl_heap_visible to reduce WAL (and eventually set VM on-access)
Melanie Plageman <melanieplageman@gmail.com>
Commits
GET /api/v1/messages/:b64id/commits
the thread's linked commits as JSON, with link sources.
API reference →
-
Remove table_scan_analyze_next_tuple unneeded parameter OldestXmin
- 284925508ae6 19 (unreleased) landed
-
Simplify visibility check in heap_page_would_be_all_visible()
- 3efe58febc3c 19 (unreleased) landed
-
Eliminate use of cached VM value in lazy_scan_prune()
- 648a7e28d7c2 19 (unreleased) landed
-
Combine visibilitymap_set() cases in lazy_scan_prune()
- 21796c267d0a 19 (unreleased) landed
-
Fix const qualification in prune_freeze_setup()
- 4877391ce894 19 (unreleased) landed
-
Simplify vacuum visibility assertion
- bd298f54a0d6 19 (unreleased) landed
-
Split heap_page_prune_and_freeze() into helpers
- e135e044572e 19 (unreleased) landed
-
Assert that cutoffs are provided if freezing will be attempted
- cd38b7e77315 19 (unreleased) landed
-
Split PruneFreezeParams initializers to one field per line
- 1e14edcea5e1 19 (unreleased) landed
-
Refactor heap_page_prune_and_freeze() parameters into a struct
- 1937ed70621e 19 (unreleased) landed
-
Make heap_page_is_all_visible independent of LVRelState
- 3e4705484e0c 19 (unreleased) landed
-
Inline TransactionIdFollows/Precedes[OrEquals]()
- 43b05b38ea4d 19 (unreleased) landed
-
Add helper for freeze determination to heap_page_prune_and_freeze
- c8dd6542bae4 19 (unreleased) landed
-
Bump XLOG_PAGE_MAGIC after xl_heap_prune change
- 4a8fb58671d3 19 (unreleased) landed
-
Correct prune WAL record opcode name in comment
- ae8ea7278c16 19 (unreleased) landed
-
Add error codes when vacuum discovers VM corruption
- 8ec97e78a771 19 (unreleased) landed
-
Remove unused xl_heap_prune member, reason
- 4b5f206de2bb 19 (unreleased) landed
-
Remove unneeded VM pin from VM replay
- 3399c265543e 19 (unreleased) landed
-
Add assert and log message to visibilitymap_set
- e3d5ddb7ca91 19 (unreleased) landed
-
Add error codes to some corruption log messages
- fd6ec93bf890 13.0 cited
Attachments
- v25-0001-Combine-visibilitymap_set-cases-in-lazy_scan_pru.patch (application/x-patch) patch v25-0001
- v25-0002-Refactor-lazy_scan_prune-VM-set-logic-into-helpe.patch (application/x-patch) patch v25-0002
- v25-0003-Set-the-VM-in-heap_page_prune_and_freeze.patch (application/x-patch) patch v25-0003
- v25-0004-Move-VM-assert-into-prune-freeze-code.patch (application/x-patch) patch v25-0004
- v25-0005-Eliminate-XLOG_HEAP2_VISIBLE-from-vacuum-phase-I.patch (application/x-patch) patch v25-0005
- v25-0006-Eliminate-XLOG_HEAP2_VISIBLE-from-empty-page-vac.patch (application/x-patch) patch v25-0006
- v25-0007-Remove-XLOG_HEAP2_VISIBLE-entirely.patch (application/x-patch) patch v25-0007
- v25-0008-Rename-GlobalVisTestIsRemovableXid-to-GlobalVisX.patch (application/x-patch) patch v25-0008
- v25-0009-Use-GlobalVisState-in-vacuum-to-determine-page-l.patch (application/x-patch) patch v25-0009
- v25-0011-Track-which-relations-are-modified-by-a-query.patch (application/x-patch) patch v25-0011
- v25-0012-Pass-down-information-on-table-modification-to-s.patch (application/x-patch) patch v25-0012
- v25-0013-Allow-on-access-pruning-to-set-pages-all-visible.patch (application/x-patch) patch v25-0013
- v25-0014-Set-pd_prune_xid-on-insert.patch (text/x-patch) patch v25-0014
On Tue, Dec 9, 2025 at 12:48 PM Melanie Plageman <melanieplageman@gmail.com> wrote: > > In this set 0001 and 0002 are independent. 0003-0007 are all small > steps toward the single change in 0007 which combines the VM updates > into the same WAL record as pruning and freezing. 0008 and 0009 are > removing the rest of XLOG_HEAP2_VISIBLE. 0010 - 0012 are refactoring > needed to set the VM during on-access pruning. 0013 - 0015 are small > steps toward setting the VM on-access. And 0016 sets the prune xid on > insert so we may set the VM on-access for pages that have only new > data. I committed 0001 and 0002. attached v25 reflects that. 0001-0004 refactoring steps for eliminate visible record from phase I (not probably independent commits in the end) 0005 eliminate XLOG_HEAP2_VISIBLE from phase I vac 0006-0007 removing the rest of XLOG_HEAP2_VISIBLE 0008-0010 refactoring for setting VM on-access 0011-0013 setting the VM on-access 0014 - setting pd_prune_xid on insert - Melanie