Skip to content

Latest commit

 

History

History
32 lines (24 loc) · 1.11 KB

README.md

File metadata and controls

32 lines (24 loc) · 1.11 KB

KVS

This project implements a key-value store database.

I'm roughly following the course schedule for the Pingcap Rust Practical Network Applications as a guide. The kvs crate is a solution to Project 2 of that course, using their tests.

The client-server work implements roughly the specification in Project 3.

Features

So far, I've completed the following work.

  • Redis Serialization protocol (RESP) from-scratch for wire messages and database storage.
  • Log-file structured storage using RESP encoded entries.
  • Automatic log compaction @ 1MB of dead data.
  • Asynchronous server and client pass messages over TCP.
  • Asynchronous db access.
  • Simple client CLI for sending messages to server.
  • Unit testing for Redis Serialization crate.
  • Raft
    • Main event loop to read RPC requests and tick timer.
    • Client / Server traits for implementing multiple network types.
    • Implemented networks for in-memory channels and gRPC communication.
    • Implemented leader election.
    • Implemented RPC handlers.

Roadmap

  • Log persistence
  • Snapshot RPC
  • Tests for server, client, and db crates.
  • Key sharding