Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sabledb-io/sabledb
Ultra fast, persistent database supporting Redis API
https://github.com/sabledb-io/sabledb
Last synced: 3 months ago
JSON representation
Ultra fast, persistent database supporting Redis API
- Host: GitHub
- URL: https://github.com/sabledb-io/sabledb
- Owner: sabledb-io
- License: bsd-3-clause
- Created: 2024-03-30T20:57:27.000Z (10 months ago)
- Default Branch: main
- Last Pushed: 2024-04-14T12:43:56.000Z (9 months ago)
- Last Synced: 2024-04-14T13:15:59.240Z (9 months ago)
- Language: Rust
- Homepage:
- Size: 2.39 MB
- Stars: 341
- Watchers: 4
- Forks: 5
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- StarryDivineSky - sabledb-io/sabledb
README
[![ubuntu-latest-build-and-test](https://github.com/sabledb-io/sabledb/actions/workflows/rust.yml/badge.svg)](https://github.com/sabledb-io/sabledb/actions/workflows/rust.yml)
[![macOS-latest](https://github.com/sabledb-io/sabledb/actions/workflows/macos-latest.yml/badge.svg)](https://github.com/sabledb-io/sabledb/actions/workflows/macos-latest.yml)# What is `SableDB`?
`SableDB` is a key-value NoSQL database that utilizes [`RocksDB`][3] as its storage engine and is compatible with the Redis protocol.
It aims to reduce memory costs and increase capacity compared to Redis. `SableDB` features include Redis-compatible access via
any Redis client, up to 64K databases support, asynchronous replication using transaction log tailing and TLS connectivity support.Oh, and it's written in `Rust` :)
## Building
`SableDB` is supported on all major OS: `Linux`, `macOS` and `Windows`
### Linux /macOS
```bash
git clone https://github.com/sabledb-io/sabledb.git
cd sabledb
cargo build --release
cargo test --release
```### Windows
On Windows, we require `MSYS2` terminal for building `SableDB`.
First, ensure that you have the required toolchain (beside Rust):
```bash
pacman -Sy git \
mingw-w64-clang-x86_64-toolchain \
mingw-w64-clang-x86_64-python3 \
mingw-w64-clang-x86_64-cmake \
mingw-w64-clang-x86_64-libffi \
unzip \
mingw-w64-clang-x86_64-gcc-compat
``````bash
git clone https://github.com/sabledb-io/sabledb.git
cd sabledb
CFLAGS="-D_ISOC11_SOURCE" cargo build --release
cargo test --release
```## Running `SableDB`
```bash
./target/release/sabledb
```Usage:
```bash
$target/release/sabledb [sabledb.ini]
```## Docker
```bash
docker build -t sabledb:latest .
docker run -p 6379:6379 sabledb:latest
```### Docker compose
If you prefer to use `docker-compose`, you can use the following command:
```bash
docker compose up --build
```### Tail logs
To tail the logs, use the below command:
```bash
docker exec -it sabledb-sabledb-1 /bin/bash -c "tail -f /var/lib/sabledb/log/sabledb.log.*"
```**Note**: the container name (in the above example: `sabledb-sabledb-1`) can be found using the command `docker ps`
## Supported features
- Persistent data using RocksDB - use `SableDB` as a persistent storage using `Redis`'s API
- TLS connections
- Replication using tailing of the transaction log
- Highly configurable, but comes with sensible default values
- Use the `sb` command line utility (`target/release/sb`) for performance testing
- Transactions ( `MULTI` / `EXEC` )## Benchmark tool - `sb`
`SableDB` uses its own benchmarking tool named `sb` ("SableDB Benchmark"). `sb` supports the following commands:
- `set`
- `get`
- `lpush`
- `lpop`
- `rpush`
- `rpop`
- `incr`
- `ping`
- `hset`Run `sb --help` to get the full help message.
Below is a simple ( `ping` ) test conducted locally using WSL2 on Windows 10 (same machine is running both `SableDB` and `sb`...):
![sb progress demo](/docs/images/sb-demo.gif)
`set` test, on the same set-up (local machine, WSL2 on Windows 10):
![sb set progress demo](/docs/images/sb-demo-set.gif)
## Supported commands
**IMPORTANT**
`SableDB` is under constant development, if you are missing a command, feel free to open an issue
and visit this page again in couple of days---
### String commands
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| append | ✓ | ✓ |
| decr | ✓ | ✓ |
| decrby | ✓ | ✓ |
| get | ✓ | ✓ |
| getdel | ✓ | ✓ |
| getex | ✓ | ✓ |
| getrange | ✓ | ✓ |
| getset | ✓ | ✓ |
| incr | ✓ | ✓ |
| incrby | ✓ | ✓ |
| incrbyfloat | ✓ | ✓ |
| lcs | ✓ | x | Does not support: `IDX`, `MINMATCHLEN` and `WITHMATCHLEN` |
| mget | ✓ | ✓ |
| mset | ✓ | ✓ |
| msetnx | ✓ | ✓ |
| psetex | ✓ | ✓ |
| set | ✓ | ✓ |
| setex | ✓ | ✓ |
| setnx | ✓ | ✓ |
| setrange | ✓ | ✓ |
| strlen | ✓ | ✓ |
| substr | ✓ | ✓ |### List commands
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| blmove | ✓ |✓ | |
| blmpop | ✓ |✓| |
| blpop | ✓ | ✓ | |
| brpop | ✓ | ✓ | |
| brpoplpush | ✓ | ✓ | |
| lindex | ✓ | ✓ | |
| linsert | ✓ | ✓ | |
| llen | ✓ | ✓| |
| lmove | ✓ | ✓ | |
| lmpop | ✓ | ✓ | |
| lpop | ✓ | ✓ | |
| lpos | ✓ | ✓ | |
| lpush | ✓ | ✓ | |
| lpushx | ✓ | ✓ | |
| lrange | ✓ | ✓ | |
| lrem | ✓ | ✓ | |
| lset | ✓ | ✓ | |
| ltrim | ✓ | ✓ | |
| rpop | ✓ | ✓ | |
| rpoplpush | ✓ | ✓ | |
| rpush | ✓ | ✓ | |
| rpushx | ✓ | ✓ | |### Hash commands
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| hset | ✓ |✓ | |
| hget | ✓ |✓ | |
| hmget | ✓ |✓ | |
| hmset | ✓ |✓ | |
| hgetall | ✓ |✓ | |
| hdel | ✓ |✓ | |
| hlen | ✓ |✓ | |
| hexists | ✓ |✓ | |
| hincrby | ✓ |✓ | |
| hincrbyfloat | ✓ |✓ | |
| hkeys | ✓ |✓ | |
| hvals | ✓ |✓ | |
| hrandfield | ✓ |✓ | |
| hscan | ✓ |✓ | |
| hsetnx | ✓ |✓ | |
| hstrlen | ✓ |✓ | |### Sorted Set (`ZSET`) commands
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| bzmpop | ✓ |✓ | |
| bzpopmax | ✓ |✓ | |
| bzpopmin | ✓ |✓ | |
| zadd | ✓ |✓ | |
| zcard | ✓ |✓ | |
| zincrby | ✓ |✓ | |
| zcount | ✓ |✓ | |
| zdiff | ✓ |✓ | |
| zdiffstore | ✓ |✓ | |
| zinter | ✓ |✓ | |
| zintercard | ✓ |✓ | |
| zinterstore | ✓ |✓ | |
| zlexcount | ✓ |✓ | |
| zmpop | ✓ |✓ | |
| zmscore | ✓ |✓ | |
| zpopmax | ✓ |✓ | |
| zpopmin | ✓ |✓ | |
| zrandmember | ✓ |✓ | |
| zrangebyscore | ✓ |✓ | |
| zrevrangebyscore | ✓ |✓ | |
| zrangebylex | ✓ |✓ | |
| zrevrangebylex | ✓ |✓ | |
| zrange | ✓ |✓ | |
| zrangestore | ✓ |✓ | |
| zrank | ✓ |✓ | |
| zrem | ✓ |✓ | |
| zremrangebylex | ✓ |✓ | |
| zremrangebyrank | ✓ |✓ | |
| zremrangebyscore | ✓ |✓ | |
| zrevrange | ✓ |✓ | |
| zrevrank | ✓ |✓ | |
| zunion | ✓ |✓ | |
| zunionstore | ✓ |✓ | |
| zscore | ✓ |✓ | |
| zscan | ✓ |✓ | |### Set commands
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| sadd | ✓ |✓ | |
| scard | ✓ |✓ | |
| sdiff | ✓ |✓ | |
| sdiffstore | ✓ |✓ | |
| sinter | ✓ |✓ | |
| sintercard | ✓ |✓ | |
| sinterstore | ✓ |✓ | |
| sismember | ✓ |✓ | |
| smismember | ✓ |✓ | |
| smembers | ✓ |✓ | |
| smove | ✓ |✓ | |
| spop | ✓ |✓ | |
| srandmember | ✓ |✓ | |
| srem | ✓ |✓ | |
| sscan | ✓ |✓ | |
| sunion | ✓ |✓ | |
| sunionstore | ✓ |✓ | |### Generic commands
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| del | ✓ |✓ | |
| ttl | ✓ |✓ | |
| exists | ✓ |✓ | |
| expire | ✓ |✓ | |
| keys | ✓ |x | Pattern uses wildcard match ( `?` and `*` ) |
| scan | ✓ |x | Pattern uses wildcard match ( `?` and `*` ) |### Server management commands
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| info | ✓ |✓ | `SableDB` has its own INFO output format |
| ping | ✓ |✓ | |
| replicaof | ✓ |✓ | |
| slaveof | ✓ |✓ | |
| command | ✓ |✓ | |
| command docs | ✓ | x | |
| flushall | ✓ | ✓ | |
| flushdb | ✓ | ✓ | |
| dbsize | ✓ | ✓ | Data is accurate for the last scan performed on the storage |### Transaction
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| multi | ✓ |✓ | |
| exec | ✓ |✓ | |
| discard | ✓ |✓ | |
| watch | ✓ |✓ | |
| unwatch | ✓ |✓ | |### Connection management commands
| Command | Supported | Fully supported? | Comment |
|---|---|---|---|
| client id | ✓ |✓ | |
| client kill | ✓ |x | supports: `client kill ID ` |
| select | ✓ |✓ | |
| ping | ✓ |✓ | |## Benchmarks
### Command `set`
| Payload size (bytes) | rps | p50 (ms) | p90 (ms) | p99 (ms) |
|---|---|---|---|---|
| 64 | 448K | 1.127 | 1.279 | 1.423 |
| 128 | 420K | 1.199 | 1.375 | 1.551 |
| 256 | 363K | 1.375 | 1.567 | 1.799 |### Command `get`
| Payload size (bytes) | rps | p50 (ms) | p90 (ms) | p99 (ms) |
|---|---|---|---|---|
| 64 | 950K | 0.495 | 0.671 | 1.087 |
| 128 | 907K | 0.511 | 0.695 | 1.111 |
| 256 | 905K | 0.519 | 0.711 | 1.119 |### Command `mset`
Note: Each `mset` command is equivalent of `10` `set` commands
| Payload size (bytes) | rps | p50 (ms) | p90 (ms) | p99 (ms) |
|---|---|---|---|---|
| 64 | 116K | 3.8 | 4.6 | 6.3 |
| 128 | 72K | 6.375 | 7.039 | 54.111 |
| 256 | 41.5K | 0.432 | 7.279 | 226.943 |### Command `incr`
The increment command is unique because it uses a "read-modify-update" in order to ensure the atomicity of the action which in a
multi-threaded environment causes a challenge| Payload size (bytes) | rps | p50 (ms) | p90 (ms) | p99 (ms) |
|---|---|---|---|---|
| N/A | 443K | 1.127 | 1.295 | 1.383 |### Network only (`ping` command)
| Command | rps | pipeline | p50 (ms) | p90 (ms) | p99 (ms) |
|---|---|---|---|---|---|
| ping_inline | 1.05M | 1 | 0.407 | 0.775 | 1.143 |
| ping_inline | 6.65M | 20 | 0.855 | 1.551 | 1.815 |
| ping_mbulk | 1.05M | 1 | 0.399 | 0.727 | 1.127 |
| ping_mbulk | 7.96M | 20 | 0.807 | 1.471 | 1.711 |---
Command executions can be seen [here][2]
[1]: https://github.com/redis/redis
[2]: https://github.com/sabledb-io/sabledb/blob/main/BENCHMARK.md
[3]: https://rocksdb.org/
[4]: https://tokio.rs/