# Batch Write and Checksums at the end of each week, we will have some easy, not important, while interesting things In this chapter, you will: * Implement the batch write interface. * Add checksums to the blocks, SST metadata, manifest, and WALs. ## Task 1: Write Batch Interface ## Task 2: Block Checksum ## Task 3: SST Checksum ## Task 4: WAL Checksum ## Task 5: Manifest Checksum ## Test Your Understanding * Consider the case that an LSM storage engine only provides `write_batch` as the write interface (instead of single put + delete). Is it possible to implement it as follows: there is a single write thread with an mpsc channel receiver to get the changes, and all threads send write batches to the write thread. The write thread is the single point to write to the database. What are the pros/cons of this implementation? (Congrats if you do so you get BadgerDB!) * Is it okay to put all block checksums altogether at the end of the SST file instead of store it along with the block? Why? We do not provide reference answers to the questions, and feel free to discuss about them in the Discord community. {{#include copyright.md}}