EloqKV EloqKV is a high-performance distributed database with a Redis/ValKey compatible API. It offers features like ACID transactions, full elasticity and scalability, tiered storage, and session-style transaction syntax — all while preserving Redis' simplicity and usability. EloqKV is engineered for developers who need a modern no-compromise database solution to power the next generation of demanding applications in the AI era. Why Choose EloqKV Over Redis? Feature Redis EloqKV High Performance Single-threaded Multi-threaded (1.6million QPS on c6g.8xlarge) Transactions MULTI/EXEC (No Rollback) Redis API plus BEGIN/COMMIT/ROLLBACK (ACID) Distributed Transactions CROSSSLOT Error ACID distributed transactions Data Durability Limited, AOF/RDB snapshots Replicated WAL + Tiered Storage Cold Data Must fit in memory Auto-tiering to disk Client Transparency Cluster needs specific client Same client for a single server or a cluster Key Features ⚡ High Performance Multi-threaded : Built with thread-per-core execution and message-passing architecture to fully utilize modern multicore CPUs. : Built with thread-per-core execution and message-passing architecture to fully utilize modern multicore CPUs. Single Node : Up to 1.6M QPS on AWS c6g.8xlarge, comparable to purpose-built cache systems like DragonflyDB and far out-performs Redis and Valkey. : Up to on AWS c6g.8xlarge, comparable to purpose-built cache systems like DragonflyDB and far out-performs Redis and Valkey. Natively Distributed: Scale horizontally with distributed transactions, so your application works the same whether it's backed by a single-node EloqKV or a cluster of servers. 🗃️ Full Durability with Tiered Storage WAL for True Durability : No more data loss due to power failures. : No more data loss due to power failures. Hot Data : In-memory for microsecond access. : In-memory for microsecond access. Cold Data: Automatically offloaded to disk. Save 70% on memory costs compared to pure in-memory cache such as Redis. 🛠️ ACID Transactions with Session-Style Syntax In addition to the standard (but limited) Redis transaction syntax (MULTI/EXEC), EloqKV also support Session-style interactive transactions. -- Transfer funds between accounts atomically BEGIN GET user:1000:balance -- returns 1000 INCRBY user:1000:balance -500 -- returns ok INCRBY user:2000:balance +500 -- returns ok COMMIT -- Rollback on failure No more Lua scripts or MULTI limitations — write transactions like a SQL database, with similar ACID gurantees and better performance. 🌐 Distributed ACID Transactions Cross-node strong consistency without hash slot constraints -- Example of cross-node transfer BEGIN INCRBY user:1000:balance -500 -- node A HSET order:2000:status "paid" -- node B COMMIT No CROSSSLOT Errors:Enables atomic operations across multiple nodes, unlike Redis Cluster which blocks cross-slot transactions. 🔄 Redis API Compatibility redis-cli -h eloqkv-server SET key " value " # Works out of the box! Zero code changes needed. Check out our supported Redis commands. Quick Start Using Docker We recommend using Docker for a quick local try-out of EloqKV. 1. Start a Single Node using Docker: # Create subnet for containers. docker network create --subnet=172.20.0.0/16 eloqnet docker run -d --net eloqnet --ip 172.20.0.10 -p 6379:6379 --name=eloqkv eloqdata/eloqkv 2. Verify Installation: redis-cli -h 172.20.0.10 172.20.0.10: 6379> set hello world OK 172.20.0.10: 6379> get hello " world " Run with EloqCtl EloqCtl is the cluster management tool for EloqKV. To deploy an EloqKV cluster in production, download EloqCtl and follow the deployment guide. Run with Tarball Download the EloqKV tarball from the EloqData website. Follow the instruction guide to set up and run EloqKV on your local machine. Architecture EloqKV is a decoupled, distributed database built on Data Substrate, the innovative new database foundation developed by EloqData. Each EloqKV instance includes a frontend, compatible with the Redis protocol, deployed together with the core TxService to handle data operations. A logically independent LogService handles Write Ahead Logging (WAL) to ensure persistence, while a Storage Service manages memory state checkpoints and cold data storage. Benchmark EloqKV is a fully featured key-value database that supports both pure in-memory caching mode and durable transactional mode. In both use cases, it delivers outstanding performance compared to other solutions. Cache Mode In cache scenarios, on a reasonable modern multi-core server EloqKV significantly outperforms Redis and ValKey and achieves performances comparable to DragonflyDB, a multi-threaded in-memory cache with Redis API. Unlike Redis and DragonflyDB, EloqKV is a full featured database that also excels in clustered, durable, and fully ACID-compliant transactional setups. 📖 See full benchmark Persistent Transactional Mode When running with full durability, EloqKV outperforms other Redis-compatible stores like Apache KVRocks by a large margin. Unlike these datastores that merely swap cold data to disks, EloqKV offers real, rollback-capable transactions with high throughput and ACID guarantees. 📖 See full benchmark Build from Source 1. Pull the Source Code and Install Dependencies We recommend using our Docker image with pre-installed dependencies and pull EloqKV source code in the container for a quick build and run of EloqKV. docker pull eloqdata/eloq-dev-ci-ubuntu2404:latest docker run -it --name eloq eloqdata/eloq-dev-ci-ubuntu2404 git clone https://github.com/eloqdata/eloqkv.git cd eloqkv Alternatively, you can also pull the source code in an existing Linux environment (currently, ubuntu2404 is preferred), and manually run the script to install dependencies on your local machine. Notice that this might take a while. git clone https://github.com/eloqdata/eloqkv.git cd eloqkv bash scripts/install_dependency_ubuntu2404.sh 2. Initialize Submodules git submodule update --init --recursive 3. Build EloqKV mkdir build cd build cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=./install .. make -j 8 make install 4. Run EloqKV cd install ./bin/eloqkv --port=6389 License EloqKV is released under a dual license. You may choose to use it under the terms of either: GNU General Public License, Version 2 (GPLv2), or GNU Affero General Public License, Version 3 (AGPLv3). See the LICENSE file for details. See Also Star This Repo ⭐ to Support Our Journey — Every Star Helps Us Reach More Developers!