I'm currently writing a book for PragProg called Building Distributed Services with Go (though it mostly applies to other languages too) that's walks you through building a distributed database from scratch. You can sign up on this mailing list to know when it's available:
https://travisjeffery.us4.list-manage.com/subscribe?u=1e3ff7...