Expand description
Fetching batches of data from persistβs backing store
StructsΒ§
- BatchFetcher 
- Capable of fetching LeasedBatchPartwhile not holding any capabilities.
- BatchFetcher πConfig 
- EncodedPart π
- A Blob object that has been fetched, but has no associated decoding logic.
- ExchangeableBatch Part 
- This represents the serde encoding for LeasedBatchPart. We expose the struct itself (unlike other encodable structs) to attempt to provide stricter drop semantics onLeasedBatchPart, i.e.SerdeLeasedBatchPartis exchangeable (including over the network), whereLeasedBatchPartis not.
- FetchConfig π
- FetchedBlob 
- A Blob object that has been fetched, but not at all decoded.
- FetchedPart 
- A Blob object that has been fetched, but not yet fully decoded.
- Lease
- This represents the lease of a seqno. Itβs generally paired with some external state, like a hollow part: holding this lease indicates that we may still want to fetch that part, and should hold back GC to keep it around.
- LeasedBatch Part 
- A token representing one fetch-able batch part.
- ShardSource Part 
- FetchedPart but with an accompanying permit from the fetch mem/disk semaphore.
EnumsΒ§
- FetchBatch πFilter 
- FetchedBlob πBuf 
- PartDecode Format 
- Format weβll use when decoding a Part.
ConstantsΒ§
- FETCH_SEMAPHORE_ πCOST_ ADJUSTMENT 
- FETCH_SEMAPHORE_ πPERMIT_ ADJUSTMENT 
- OPTIMIZE_IGNORED_ πDATA_ FETCH 
- PART_DECODE_ πFORMAT 
- VALIDATE_PART_ πBOUNDS_ ON_ READ 
FunctionsΒ§
- decode_batch_ πpart_ blob 
- fetch_batch_ πpart 
- fetch_batch_ πpart_ blob 
- fetch_leased_ πpart 
- Trade in an exchange-able LeasedBatchPart for the data it represents.