Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alttch/yedb-rs
Rugged embedded and client/server key-value database (Rust implementation)
https://github.com/alttch/yedb-rs
client-server crash-free database iot key-value reliable rugged rust
Last synced: about 2 months ago
JSON representation
Rugged embedded and client/server key-value database (Rust implementation)
- Host: GitHub
- URL: https://github.com/alttch/yedb-rs
- Owner: alttch
- License: apache-2.0
- Created: 2021-02-21T12:26:56.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-03-05T01:49:38.000Z (10 months ago)
- Last Synced: 2024-10-12T23:15:07.512Z (3 months ago)
- Topics: client-server, crash-free, database, iot, key-value, reliable, rugged, rust
- Language: Rust
- Homepage:
- Size: 515 KB
- Stars: 19
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# yedb - rugged crash-free embedded and client/server key-value database (Rust implementation)
## Cargo crate
[crates.io/crates/yedb](https://crates.io/crates/yedb)
Features:
- **client-sync** synchronous client
- **client-async** asynchronous client
- **cli** yedb-cli
- **server** yedb-server## Why YEDB?
- Is it fast?
- Rust version is pretty fast, except writes are still slow if auto-flush is
enabled.- Is it smart?
- No- So what is YEDB for?
- YEDB is ultra-reliable, thread-safe and very easy to use.- I don't like Rust
- There are other [implementations](https://yedb.bma.ai).[![Power loss data survive
demo](https://img.youtube.com/vi/i3hSWjrNqLo/0.jpg)](https://www.youtube.com/watch?v=i3hSWjrNqLo)YEDB is absolutely reliable rugged key-value database, which can survive in any
power loss, unless the OS file system die. Keys data is saved in the very
reliable way and immediately flushed to disk (this can be disabled to speed up
the engine but is not recommended - why then YEDB is used for).## Rust version features
- Rust version is built on top of [Serde](https://serde.rs) framework.
- All key values are *serde_json::Value* objects.
- Storage serialization formats supported: JSON (default), YAML, MessagePack
and CBOR.- As byte type is not supported by *serde_json::Value* at this moment, Rust
version can not handle byte key values.- Contains: embedded library, async server and command-line client (TCP/Unix
socket only).- The command-line client is very basic. If you need more features, use [yedb
Python CLI](https://github.com/alttch/yedb-py).## Additional features over YEDB specs
- "delete" command does not delete keys, they are moved to .trash folder
instead- .trash folder is being cleaned when "purge" method is invoked.
- "auto\_bak" property tells server to automatically create backup key versions
when key data is modified- "bak" keys are hidden
## Client/server
Binaries available at the [releases
page](https://github.com/alttch/yedb-rs/releases).Run server:
```shell
./yedb-server /tmp/db1
```Use client:
```shell
# get server info
./yedb-cli info
# set key value
./yedb-cli set x 5 -p number
# list all keys
./yedb-cli ls /
# edit key with $EDITOR
./yedb-cli edit x
# get key as JSON
./yedb-cli get x
# get help for all commands
./yedb-cli -h
```## Code examples
The database/client objects can be safely shared between threads using any kind
of Lock/Mutex preferred.### Embedded example
```rust,ignore
use yedb::Database;
use serde_json::Value;let mut db = Database::new();
db.set_db_path("/tmp/db1").unwrap();
db.open().unwrap();
let key_name = "test/key1";
db.key_set(&key_name, Value::from(123_u8)).unwrap();
println!("{:?}", db.key_get(&key_name));
db.key_delete(&key_name).unwrap();
db.close().unwrap();
```### TCP/Unix socket client example
```rust,ignore
use yedb::YedbClient;
use serde_json::Value;let mut client = YedbClient::new("tcp://127.0.0.1:8870");
let key_name = "test/key1";
client.key_set(&key_name, Value::from(123_u8)).unwrap();
println!("{:?}", client.key_get(&key_name));
client.key_delete(&key_name).unwrap();
```### Async TCP/Unix socket client example
```rust,ignore
use serde_json::Value;
use yedb::{YedbClientAsync, YedbClientAsyncExt};async fn test() {
let mut client = YedbClientAsync::new("tcp://127.0.0.1:8870");
let key_name = "test/key1";
client.key_set(&key_name, Value::from(123_u8)).await.unwrap();
println!("{:?}", client.key_get(&key_name).await);
client.key_delete(&key_name).await.unwrap();
}
```### Async TCP/Unix socket client pool example
```rust,ignore
use serde_json::Value;
use std::sync::Arc;
use std::time::Duration;
use yedb::{YedbClientPoolAsync, YedbClientAsyncExt};async fn test() {
let pool = Arc::new(
YedbClientPoolAsync::create()
.size(10)
.path("tcp://127.0.0.1:8870")
.retries(3)
.timeout(Duration::from_secs(2))
.build()
);
let mut futs = Vec::new();
for i in 0..10 {
let task_pool = pool.clone();
let fut = tokio::spawn(async move {
let mut client = task_pool.get().await;
let key = format!("test/key{}", i);
client.key_set(&key, Value::from(i)).await.unwrap();
println!("{}", client.key_get(&key).await.unwrap());
client.key_delete(&key).await.unwrap();
});
futs.push(fut);
}
for fut in futs {
fut.await.unwrap();
}
}
```## Specification
[yedb.bma.ai](https://yedb.bma.ai/)
## Some benchmark data
* CPU: Intel Core i7-8550U (4 cores)
* Drive: Samsung MZVLB512HAJQ-000L7 (NVMe)- auto\_flush: false
- connection: Unix socket
- server workers: 2
- client threads: 4```shell
set/number: 8164 ops/sec
set/string: 7313 ops/sec
set/array: 7152 ops/sec
set/object: 5272 ops/secget/number: 49709 ops/sec
get/string: 33338 ops/sec
get/array: 31426 ops/sec
get/object: 11654 ops/secget(cached)/number: 122697 ops/sec
get(cached)/string: 61206 ops/sec
get(cached)/array: 59309 ops/sec
get(cached)/object: 34583 ops/secincrement: 7079 ops/sec
```