Skip to content

Bf-Tree: A Modern Read-Write-Optimized Concurrent Larger-Than-Memory Range Index

Notifications You must be signed in to change notification settings

XiangpengHao/bf-tree-docs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Bf-Tree

Paper: Latest, VLDB 2024

Slides: PowerPoint, pdf

Poster: VLDB 2024

Code: see below


Bf-Tree is a modern read-write-optimized concurrent larger-than-memory range index.

  • Modern: designed for modern SSDs, implemented with modern programming languages (Rust).

  • Read-write-optimized: 2.5× faster than RocksDB for scan operations, 6× faster than a B-Tree for write operations, and 2× faster than both B-Trees and LSM-Trees for point lookup -- for small records (e.g. ~100 bytes).

  • Concurrent: scale to high thread count.

  • Larger-than-memory: scale to large data sets.

  • Range index: records are sorted.

The core of Bf-Tree are the mini-page abstraction and the buffer pool to support it.

Thank you for your time on Bf-Tree, I'm all ears for feedbacks!

Mini-pages

1. As a record-level cache

More fine-grained than page-level cache, which is more efficient at identifying individual hot records. Mini-pages serves as a record level cache

2. As a write buffer

Mini pages absorb writes records and batch flush them to disk. Mini-pages serves as a write buffer

3. Grow/shrink in size

Mini-pages grow and shrink in size to be more precise in memory usage.

Mini-pages grow and shrink in size

4. Flush to disk

Mini-pages are flushed to disk when they are too large or too cold.

Mini-pages are flushed to disk

Buffer pool for mini-pages

The buffer pool is a circular buffer, allocated space is defined by head and tail address.

1. Allocate mini-pages

Allocate mini-pages

2. Evict mini-pages when full

Evict mini-pages when full

3. Track hot mini-pages

Naive circular buffer is a fifo queue, we make it a LRU-approximation using the second chance region.

Mini-pages in the second-chance region are:

  • Copy-on-accessed to the tail address
  • Evicted to disk if not being accessed while in the region

Track hot mini-pages

4. Grow mini-pages

Mini-pages are copied to a larger mini-page when they need to grow. The old space is added to a free list for future allocations.

Grow mini-pages

Show me the code!

Bf-Tree is currently internal to Microsoft. I'll update here once we figured out the next steps.

Is Bf-Tree deployed in production?

No. The prototype I implemented is not deployed in production yet.

However, the circular buffer pool design is very similar to FASTER's hybrid log, which is deployed in production at Microsoft.

What are the drawbacks of Bf-Tree?

  • Bf-Tree only works for modern SSDs where parallel random 4KB writes have similar throughput to sequential writes. While not all SSDs have this property, it is not uncommon for modern SSDs.

  • Bf-Tree is heavily optimized for small records (e.g., 100 bytes, a common size when used as secondary indexes). Large records will have a similar performance to B-Trees or LSM-Trees.

  • Bf-Tree's buffer pool is more complex than B-Tree and LSM-Trees, as it needs to handle variable length mini-pages. But it is simpler than Bw-Tree in my opinion, which is implemented & deployed in production.

Add your opinions here!

Future directions?

  • Bf-Tree in-place writes to disk pages, which can cause burden to SSD garbage collection. If it is indeed a problem, we should consider using log-structured write to disk pages.

  • Bf-Tree's mini-page eviction/promotion policy is dead simple. More advanced policies can be used to ensure fairness, improve hit rate, and reduce copying. Our current paper focus on mini-page/buffer pool mechanisms, and exploring advanced policies is left as future work.

  • Better async. Bf-Tree relies on OS threads to interleave I/O operations, many people believe this is not ideal. Implement Bf-Tree with user-space async I/O (e.g., tokio) might be a way to publish paper.

  • Go lock/latch free. Bf-Tree is lock-based, and is carefully designed so that no dead lock is possible. Adding lock-free to the paper title is cool -- if you are a lock-free believer.

  • Future hardware. It's not too difficult to imagine 10 more papers on applying Bf-Tree to future hardwares, like CXL, RDMA, PM, GPU, SmartNic etc.

I got questions!

If you encounter any problems or have questions about implementation details, I'm more than happy to help you out and give you some hints! Feel free to reach out to me at [email protected] or open an issue here.

Errata

Some notable changes:

  • We have fixed a legend typo in Figure 1.

Cite Bf-Tree

@article{bf-tree,
  title={Bf-Tree: A Modern Read-Write-Optimized Concurrent Larger-Than-Memory Range Index},
  author={Hao, Xiangpeng and Chandramouli, Badrish},
  journal={Proceedings of the VLDB Endowment},
  volume={17},
  number={11},
  pages={3442--3455},
  year={2024},
  publisher={VLDB Endowment}
}

Community discussions

Add yours here!

About

Bf-Tree: A Modern Read-Write-Optimized Concurrent Larger-Than-Memory Range Index

Topics

Resources

Stars

Watchers

Forks