Re: index prefetching
Peter Geoghegan <pg@bowt.ie>
Commits
GET /api/v1/messages/:b64id/commits
the thread's linked commits as JSON, with link sources.
API reference →
-
aio: io_uring: Trigger async processing for large IOs
- a9ee66881744 19 (unreleased) landed
-
read stream: Split decision about look ahead for AIO and combining
- 8ca147d582a5 19 (unreleased) landed
-
read_stream: Only increase read-ahead distance when waiting for IO
- f63ca3379025 19 (unreleased) landed
-
read_stream: Prevent distance from decaying too quickly
- 6e36930f9aaf 19 (unreleased) landed
-
Reduce ExecSeqScan* code size using pg_assume()
- b227b0bb4e03 19 (unreleased) cited
-
Fix rare bug in read_stream.c's split IO handling.
- b421223172a2 19 (unreleased) cited
-
Fix multiranges to behave more like dependent types.
- 3e8235ba4f9c 17.0 cited
-
Add EXPLAIN (MEMORY) to report planner memory consumption
- 5de890e3610d 17.0 cited
-
Optimize nbtree backward scan boundary cases.
- c9c0589fda0e 17.0 cited
-
Increment xactCompletionCount during subtransaction abort.
- 90c885cdab8b 14.0 cited
-
Add nbtree Valgrind buffer lock checks.
- 4a70f829d86c 14.0 cited
-
Add nbtree high key "continuescan" optimization.
- 29b64d1de7c7 12.0 cited
-
Reduce pinning and buffer content locking for btree scans.
- 2ed5b87f96d4 9.5.0 cited
-
Teach btree to handle ScalarArrayOpExpr quals natively.
- 9e8da0f75731 9.2.0 cited
Attachments
- v20251102-0001-bufmgr-aio-Prototype-for-not-waiting-for-a.patch (application/octet-stream) patch v20251102-0001
- v20251102-0003-Reduce-malloc-free-traffic-by-caching-batc.patch (application/octet-stream) patch v20251102-0003
- v20251102-0002-Add-amgetbatch-interface-for-index-scan-pr.patch (application/octet-stream) patch v20251102-0002
On Sun, Oct 12, 2025 at 2:52 PM Peter Geoghegan <pg@bowt.ie> wrote: > Attached in a new revision, mostly just to keep CFBot happy following > a recent trivial conflict introduced on master. Attached is another revision, also just to keep CFBot happy following a conflict introduced on master. Nothing really new here (I've been working on batching on the table AM side, but nothing to show on that just yet). One minor thing to note about this revision: I added a comment to selfuncs.c's that notes that there's an unfixed bug there. That code more or less copies the approach used by nodeIndexonlyscan.c, but neglects to take the same precautions around the read stream/prefetching see different pages as all-visible that the view seen on the consumer side. ISTM that the right fix there is to totally rethink the interface such that the read stream is directly owned by the table AM. That way we won't have to work around inconsistent ideas around which heap pages are all-visible because there'll only be one view of that, in a single place. We won't have to do anything special in either selfuncs.c or in nodeIndexonlyscan.c. -- Peter Geoghegan