Right now I've got a couple books in queue.
"Black Hat Go" Go Programming for Hackers and Pentesters by Tom Steele, Chris Patten, and Dan Kottmann.
I picked this book up after a good look at the index. There is a basic intro to Go at the beginning of the book to cover language fundamentals, but immediately after that dives into the meat of the topic. Immediately getting into understanding the TCP handshake, TCP itself, writing a scanner, and a proxy. There is then some basics about HTTP Servers, routers, and middleware in chapter 3 and 4, but returns immediately into topics of interest in chapter 5 around exploiting DNS, and writing DNS clients. I perused the index a bit further to note it covers SMB and NTLM, a chapter on "Abusing Databases and Filesystems", then on to raw packet processing, writing and porting exploit code, and a host of other topics. This is going to be an interesting book to dig into and write about in the coming weeks. I'm pretty excited about it and hope to write a thorough review upon completion.
"Designing Data-Intensive Applications" by Martin Kleppmann
This book is familiar territory, as I've spent much of my career working on similar topics that this book covers. What I suspect is that I'll enjoy reading the material presented in an orderly and concise way versus the chaos and disruptive way I've acquired the knowledge on these topics.
From the index, the book starts off with foundations of data systems and the ideas around building reliable, scalable, and maintainable applications. This provides a good basis in which to dive into the other topics. From there it looks like we'll get a run into the birth of NoSQL, object-relational mismatches and the related insanity that this has bred in the industry! Then a solid dive into graph-like, traditional, and multi-model data modeling. With the beginning quarter of the book then covering everything from hash indexes, SSTables (another familiar topic), LSM-Trees, B-Trees, and related indexing structures before wrapping up this first 25% of the book with stars and snowflake topics for analytics and column-oriented storage, compression, sort orders in column storage, and related material on aggregation in data cubes and materialized views.
That's just the first 25%! From there Martin covers a wide range of topics, that if you're in the industry and plan to deal with large scale data-intensive applications these are topics you need to be intimently familiar with!
Reading
Over the next few months while I read through these books I hope to provide summaries and related notes on the material. Who knows, maybe you'll want to dive into the material yourself! Until then happy thrashing code and may you have high retention and comprehension in reading!
Top comments (2)
This is a nice selection of books. For me, I would like to read "Designing Data-Intensive Applications" because it looks like it's covering topics that interest me a lot like scalability.
I'm really looking forward to that one too. I really enjoy working in the industry specifically on this type of work - data sizing, scaling, ETL, and all that. Thanks for checking out my list! 👍🏻