Papers
Topics
Authors
Recent
Gemini 2.5 Flash
Gemini 2.5 Flash
149 tokens/sec
GPT-4o
9 tokens/sec
Gemini 2.5 Pro Pro
47 tokens/sec
o3 Pro
4 tokens/sec
GPT-4.1 Pro
38 tokens/sec
DeepSeek R1 via Azure Pro
28 tokens/sec
2000 character limit reached

FB$^+$-tree: A Memory-Optimized B$^+$-tree with Latch-Free Update (2503.23397v1)

Published 30 Mar 2025 in cs.DB, cs.DS, and cs.PF

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

We haven't generated a summary for this paper yet.

X Twitter Logo Streamline Icon: https://streamlinehq.com