#radix-tree #art #concurrency #adaptive-radix-tree #locking

nightly con-art-rust

A Rust implementation of ART-OLC concurrent adaptive radix tree

10 releases

0.2.0 Feb 15, 2022
0.1.8 Feb 1, 2022
0.1.7 Jan 29, 2022

#830 in Database interfaces

Download history 39/week @ 2024-02-26 2/week @ 2024-03-11 68/week @ 2024-04-01

70 downloads per month

MIT license

98KB
2.5K SLoC

Concurrent ART (adaptive radix tree)

con-art-rust Crates.io dependency status codecov Documentation

A Rust implementation of ART-OLC concurrent adaptive radix tree. It implements the optimistic lock coupling with proper SIMD support.

It only supports (and is optimized for) 8 byte key; due to this specialization, this ART has great performance -- basic operations are ~40% faster than flurry hash table, range scan is an order of magnitude faster.

The code is extensively tested with {address|leak} sanitizer as well as libfuzzer.

Why this library?

  • Fast performance, faster than most hash tables.
  • Concurrent, super scalable, it reaches 150Mop/s on 32 cores.
  • Super low memory consumption. Hash tables often have exponential bucket size growth, which often lead to low load factors. ART is more space efficient.

Why not this library?

  • Not for arbitrary key size. This library only supports 8 byte key.
  • The value must be a valid, user-space, 64 bit pointer, aka non-null and zeros on 48-63 bits.
  • Not for sparse keys. ART is optimized for dense keys, if your keys are sparse, you should consider a hashtable.

Example:

use con_art_rust::Art;
let art = Art::new();
let guard = art.pin(); // enter an epoch

art.insert(0, 42, &guard); // insert a value
let val = art.get(&0).unwrap(); // read the value
assert_eq!(val, 42);

let mut scan_buffer = vec![0; 8];
let scan_result = art.range(&0, &10, &mut art_scan_buffer); // scan values
assert_eq!(scan_result.unwrap(), 1);

Dependencies

~0.2–29MB
~355K SLoC