# LSM in a Week [![CI (main)](https://github.com/skyzh/mini-lsm/actions/workflows/main.yml/badge.svg)](https://github.com/skyzh/mini-lsm/actions/workflows/main.yml) Build a simple key-value storage engine in a week! ## Tutorial The tutorial is available at [https://skyzh.github.io/mini-lsm](https://skyzh.github.io/mini-lsm). You can use the provided starter code to kick off your project, and follow the tutorial to implement the LSM tree. ## Development ``` cargo x install-tools cargo x check cargo x book ``` If you changed public API in the reference solution, you might also need to synchronize it to the starter crate. To do this, use `cargo x sync`. ## Progress We are working on a new version of the mini-lsm tutorial that is split into 3 weeks. * Week 1: Storage Format + Engine Skeleton * Week 2: Compaction and Persistence * Week 3: Multi-Version Concurrency Control | Week + Chapter | Topic | Solution | Starter Code | Writeup | | ---- | ------------------ | --------------- | ----------------- | --------- | | 1.1 | Block Format | ✅ | ✅ | ✅ | | 1.2 | Table Format | ✅ | ✅ | ✅ | | | 1.3 | Memtables | ✅ | ✅ | ✅ | | | 1.4 | Merge Iterators | ✅ | ✅ | ✅ | | 1.5 | Storage Engine - Read Path | ✅ | ✅ | ✅ | | 1.6 | Storage Engine - Write Path | ✅ | ✅ | ✅ | | 2.1 | Compaction Framework | ✅ | 🚧 | 🚧 | | 2.2 | Compaction Strategy | 🚧 | | | | 2.3 | Manifest | | | | | 2.4 | Write-Ahead Log | | | | | 2.5 | Bloom Filter and Key Compression | | | | | 2.6 | Benchmarking | | | | | 3.1 | Timestamp Encoding + Prefix Bloom Filter | | | | | 3.2 | Snapshot Read | | | | | 3.3 | Watermark and Garbage Collection | | | | | 3.4 | Transactions | | | | | 3.5 | Serializable Snapshot Isolation | | | | | 3.6 | What's Next... | | | |