Simple and modular write-ahead-logging implementation.
use growthring::{WALStoreAIO, wal::WALLoader};
use futures::executor::block_on;
let store = WALStoreAIO::new("./walfiles", true, |_, _| {Ok(())});
let mut wal = WALLoader::new(9, 8, 1000).recover(store).unwrap();
for f in wal.grow(vec!["record1(foo)", "record2(bar)", "record3(foobar)"]).into_iter() {
let ring_id = block_on(f).unwrap().1;
println!("WAL recorded record to {:?}", ring_id);
}
let store = WALStoreAIO::new("./walfiles", false, |payload, ringid| {
println!("recover(payload={}, ringid={:?})",
std::str::from_utf8(&payload).unwrap(),
ringid);
Ok(())
});
let mut wal = WALLoader::new(9, 8, 1000).recover(store).unwrap();
let ring_ids = wal.grow((0..100).into_iter().map(|i| "a".repeat(i)).collect::<Vec<_>>())
.into_iter().map(|f| block_on(f).unwrap().1).collect::<Vec<_>>();
block_on(wal.peel(ring_ids)).unwrap();
let store = WALStoreAIO::new("./walfiles", false, |payload, _| {
println!("payload.len() = {}", payload.len());
Ok(())
});
let wal = WALLoader::new(9, 8, 1000).recover(store).unwrap();