| 
									
										
										
										
											2022-12-23 15:52:09 -05:00
										 |  |  | # LSM in a Week
 | 
					
						
							| 
									
										
										
										
											2022-12-23 14:29:32 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-20 19:27:36 +08:00
										 |  |  | [Preface](./00-preface.md) | 
					
						
							|  |  |  | [Mini-LSM Overview](./00-overview.md) | 
					
						
							|  |  |  | [Environment Setup](./00-get-started.md) | 
					
						
							| 
									
										
										
										
											2022-12-23 15:52:09 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-20 19:27:36 +08:00
										 |  |  | - [Week 1 Overview: Mini-LSM](./week1-overview.md) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:00:36 +08:00
										 |  |  |   - [Memtable](./week1-01-memtable.md) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:15:01 +08:00
										 |  |  |   - [Merge Iterator](./week1-02-merge-iterator.md) | 
					
						
							|  |  |  |   - [Block](./week1-03-block.md) | 
					
						
							|  |  |  |   - [Sorted String Table (SST)](./week1-04-sst.md) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:00:36 +08:00
										 |  |  |   - [Read Path](./week1-05-read-path.md) | 
					
						
							|  |  |  |   - [Write Path](./week1-06-write-path.md) | 
					
						
							|  |  |  |   - [Snack Time: SST Optimizations](./week1-07-sst-optimizations.md) | 
					
						
							| 
									
										
										
										
											2024-01-10 14:25:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-26 16:59:03 +08:00
										 |  |  | - [Week 2 Overview: Compaction + Persistence](./week2-overview.md) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:00:36 +08:00
										 |  |  |   - [Compaction Implementation](./week2-01-compaction.md) | 
					
						
							|  |  |  |   - [Simple Compaction Strategy](./week2-02-simple.md) | 
					
						
							|  |  |  |   - [Tiered Compaction Strategy](./week2-03-tiered.md) | 
					
						
							|  |  |  |   - [Leveled Compaction Strategy](./week2-04-leveled.md) | 
					
						
							|  |  |  |   - [Manifest](./week2-05-manifest.md) | 
					
						
							|  |  |  |   - [Write-Ahead Log (WAL)](./week2-06-wal.md) | 
					
						
							| 
									
										
										
										
											2024-01-24 17:37:34 +08:00
										 |  |  |   - [Snack Time: Batch Write and Checksums (WIP)](./week2-07-snacks.md) | 
					
						
							| 
									
										
										
										
											2024-01-19 12:00:36 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-24 17:37:34 +08:00
										 |  |  | - [Week 3 Overview: MVCC (WIP)](./week3-overview.md) | 
					
						
							| 
									
										
										
										
											2024-01-26 16:59:03 +08:00
										 |  |  |   - [Timestamp Encoding + Refactor](./week3-01-ts-key-refactor.md) | 
					
						
							|  |  |  |   - [Snapshots - Memtables and SSTs](./week3-02-snapshot-read-part-1.md) | 
					
						
							|  |  |  |   - [Snapshots - Engine Read Path](./week3-03-snapshot-read-part-2.md) | 
					
						
							|  |  |  |   - [Watermark and GC](./week3-04-watermark.md) | 
					
						
							|  |  |  |   - [Transaction and OCC](./week3-05-txn-occ.md) | 
					
						
							|  |  |  |   - [Serializable Snapshot Isolation](./week3-06-serializable.md) | 
					
						
							|  |  |  |   - [Snack Time: Compaction Filter](./week3-07-compaction-filter.md) | 
					
						
							| 
									
										
										
										
											2024-01-20 19:33:06 +08:00
										 |  |  | - [The Rest of Your Life (TBD)](./week4-overview.md) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | --- | 
					
						
							| 
									
										
										
										
											2022-12-24 23:51:30 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-26 17:05:21 +08:00
										 |  |  | # DEPRECATED Mini-LSM v1
 | 
					
						
							| 
									
										
										
										
											2022-12-24 23:51:30 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-20 19:33:06 +08:00
										 |  |  | - [Overview](./00-v1.md) | 
					
						
							|  |  |  |   - [Store key-value pairs in little blocks](./01-block.md) | 
					
						
							|  |  |  |   - [And make them into an SST](./02-sst.md) | 
					
						
							|  |  |  |   - [Now it's time to merge everything](./03-memtable.md) | 
					
						
							|  |  |  |   - [The engine is on fire](./04-engine.md) | 
					
						
							|  |  |  |   - [Let's do something in the background](./05-compaction.md) | 
					
						
							|  |  |  |   - [Be careful when the system crashes](./06-recovery.md) | 
					
						
							|  |  |  |   - [A good bloom filter makes life easier](./07-bloom-filter.md) | 
					
						
							|  |  |  |   - [Save some space, hopefully](./08-key-compression.md) | 
					
						
							|  |  |  |   - [What's next](./09-whats-next.md) |