Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/nhyne/zeyrho-kv


https://github.com/nhyne/zeyrho-kv

Last synced: about 1 month ago
JSON representation

Awesome Lists containing this project

README

        

## Zeyrho ~Queue~ KV Store

Originally I was going to build a queue but a lot of the problems from DDIA involve concurrent writes and reads, which is not as large of an issue in a queue.

The long term plan of this project is to accomplish 3 things:

1. Learn (some) Rust, hopefully a lot
2. Learn distributed systems by building a basic distributed KV Store that has things like failover, replication, etc...
3. Teach other people distributed systems

Those are some pretty lofty goals, breaking them down into smaller parts:

1. Simple KV Store that can be used in a basic rust program. Nothing fancy at all, no forking or anything.
2. Make that KV Store memory safe across processes -- this is not distributed "systems" but still has some interesting learning / teaching points IRT memory safety, locks, concurrent writes, etc...
3. Turn the memory safe KV Store into a grpc (or http) server
4. Build replication into the server, i.e. a secondary server can be spun up and "follow" a leader
5. Build "new node coming online" logic -- catching up so to speak and then streaming data
6. Build journaling support for when too much is being written
7. Build in failover
1. This probably will need to be broken down into smaller parts
2. Do we want a control plane? This is where we'll dive into more DS topics and look at tradeoffs
8. Other? There are a lot of stretch goals
1. Concurrent writes
2. Partitioning
3. Transactions?

## TODO / Plans

- [x] Journal writes
- [ ] Replication
- [ ] New node coming online
- [ ] Failover
- [ ] Leader election -- before doing anything complicated this can just be a single node that picks a random available server
- [ ] Partitioning? -- This doesn't seem as helpful as other topics
- [ ] Transactions
- Transactions is a big topic, it's going to take a while to come up with a list of things that are achievable for a toy KV Store.

### Nix setup for intellij

The toolchain path is where cargo is listed after running `which -a cargo`. You have to pick the correct version based on the toolchain for the project.

The std-lib needs to be downloaded with `rustup -v component add rust-src` and then lives in the same path as cargo like `/home/nhyne/.rustup/toolchains/nightly-2024-09-17-x86_64-unknown-linux-gnu/lib/rustlib/src/rust`.