Papers
Topics
Authors
Recent
Search
2000 character limit reached

FB$^+$-tree: A Memory-Optimized B$^+$-tree with Latch-Free Update

Published 30 Mar 2025 in cs.DB, cs.DS, and cs.PF | (2503.23397v1)

Abstract: B$+$-trees are prevalent in traditional database systems due to their versatility and balanced structure. While binary search is typically utilized for branch operations, it may lead to inefficient cache utilization in main-memory scenarios. In contrast, trie-based index structures drive branch operations through prefix matching. While these structures generally produce fewer cache misses and are thus increasingly popular, they may underperform in range scans because of frequent pointer chasing. This paper proposes a new high-performance B$+$-tree variant called \textbf{Feature B$+$-tree (FB$+$-tree)}. Similar to employing bit or byte for branch operation in tries, FB$+$-tree progressively considers several bytes following the common prefix on each level of its inner nodes\textemdash referred to as features, which allows FB$+$-tree to benefit from prefix skewness. FB$+$-tree blurs the lines between B$+$-trees and tries, while still retaining balance. In the best case, FB$+$-tree almost becomes a trie, whereas in the worst case, it continues to function as a B$+$-tree. Meanwhile, a crafted synchronization protocol that combines the link technique and optimistic lock is designed to support efficient concurrent index access. Distinctively, FB$+$-tree leverages subtle atomic operations seamlessly coordinated with optimistic lock to facilitate latch-free updates, which can be easily extended to other structures. Intensive experiments on multiple workload-dataset combinations demonstrate that FB$+$-tree shows comparable lookup performance to state-of-the-art trie-based indexes and outperforms popular B$+$-trees by 2.3x$\ \sim\ $3.7x under 96 threads. FB$+$-tree also exhibits significant potential on other workloads, especially update workloads under contention and scan workloads.

Summary

No one has generated a summary of this paper yet.

Paper to Video (Beta)

No one has generated a video about this paper yet.

Whiteboard

No one has generated a whiteboard explanation for this paper yet.

Open Problems

We haven't generated a list of open problems mentioned in this paper yet.

Continue Learning

We haven't generated follow-up questions for this paper yet.

Authors (4)

Collections

Sign up for free to add this paper to one or more collections.

Tweets

Sign up for free to view the 1 tweet with 0 likes about this paper.