Skip to content
/ sparkv Public

Expirable in-memory key-value store for Rust with no dependencies

License

Notifications You must be signed in to change notification settings

uzyn/sparkv

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SparKV

SparKV is an expirable in-memory key-value store for Rust.

Features

  1. Flexible expiration duration (a.k.a. time-to-live or TTL) per entry instead of database-wide common TTL.
    1. This is similar to that of DNS where each entries of the same domain can have its own unique TTL.
  2. Automatically clears expired entries by default.
  3. String-based key-value store.
  4. Fast data entry enforcements, including ensuring entry size, database size and max TTL.
  5. SparKV is intentionally not an LRU cache.
  6. Configurable.

Usage

Add SparKV crate to your Cargo dependencies:

$ cargo add sparkv

Quick start

use sparkv::SparKV;

let mut sparkv = SparKV::new();
sparkv.set("your-key", "your-value"); // write
let value = sparkv.get("your-key").unwrap(); // read

// Write with unique TTL
sparkv.set_with_ttl("diff-ttl", "your-value", std::time::Duration::from_secs(60));

See config.rs for more configuration options.

TODO

  1. Documentations
  2. Support generic data types

License

MIT License
Copyright © 2024 U-Zyn Chua

Releases

No releases published

Packages

No packages published

Languages