/fixing-monoliths-book

Principles of Software Architecture Modernization

Primary LanguageHTMLThe UnlicenseUnlicense

Principles of Software Architecture Modernization

Delivering engineering excellence with the art of fixing microservices, monoliths, and distributed monoliths.

This is the Code repository for the book.

How to Buy?

BPB: https://bpbonline.com/products/principles-of-software-architecture-modernization

Amazon: https://www.amazon.com/Principles-Software-Architecture-Modernization-microservices-ebook/dp/B0CP95X2GV/ref=sr_1_1?crid=3JNWE3JNJDR6&keywords=Principles+of+Software+Architecture+Modernization&qid=1701557697&sprefix=principles+of+software+architecture+modernization%2Caps%2C139&sr=8-1

About the author

Diego Pacheco(https://diegopacheco.github.io/) is a seasoned, experienced Brazilian software architect, author, speaker, technology mentor, and DevOps practitioner with more than 20+ years of solid experience. I've been building teams and mentoring people for more than a decade, teaching soft skills and technology daily. Selling projects, hiring, building solutions, running coding dojos, long retrospectives, weekly 1:1s, design sessions, code reviews, and my favorite debate club: architects community of practices and development groups for more than a decade. Live, breathe, and practice real agile since 2005, coaching teams have helped many companies to discover better ways to work using Lean, Agile principles, and methods like XP and DTA. I've led complex architecture teams and engineering teams at scale guided by SOA principles, using a variety of open-source languages like Java, Scala, Rust, Go, Python, Groovy, JavaScript, and TypeScript, cloud providers like AWS Cloud and Google GCP, amazing solutions like Akka, ActiveMQ, Netty, Tomcat, and Gatling, NoSQL databases like Cassandra, Redis, Elasticache Redis, Elasticsearch, Opensearch, RabbitMQ, libraries like Spring, Hibernate, and Spring Boot and also the NetflixOSS Stack: Simian Army, RxJava, Karyon, Dynomite, Eureka, and Ribbon. I’ve implemented complex security solutions at scale using AWS KMS, S3, Containers (ECS and EKs), Terraform, and Jenkins. Over a decade of experience as a consultant, coding, designing, and training people at big customers in Brazil, London, Barcelona, India, and the USA(Silicon Valley and Midwest). I have a passion for functional programming and distributed systems, NoSQL Databases, an obsession for Observability, and always learning new programming languages. Currently working as a principal Software Architect with AWS public cloud, Kubernetes/ EKS, performing complex cloud migrations, library migrations, server and persistence migrations, and security at scale with multi-level envelope encryption solutions using KMS and S3. While still hiring, teaching, mentoring, and growing engineers and architects. During my free time, I love playing with my daughter, playing guitar, gaming, coding pocs, and blogging. http://diego-pacheco.blogspot.com.br/.

diegopacheco

@diego_pacheco

diegopachecors

Diego Pacheco Youtube Channel

Diego Pacheco Tech Blog

@diego_pacheco

About the co-author

Sam Sgro is an experienced technologist, architect, and engineering leader with decades of hands-on experience. Sam is a strong believer in how combining logic and reason with the right principles can bring about a better world, and his career has been about applying architecture and engineering in the best possible way, solving complex business and technology problems to help people. Sam’s early background was a mix of both molecular biology and computer science, working in projects spanning open-source cryptography and high-performance computing. Slowly transitioning from having fun with Solaris and Linux to Java software engineering, Sam joined an early-stage bioinformatics and data analytics startup with a successful exit to Thomson Reuters. Since then, Sam has served as an engineering and architecture leader for teams across the US, Canada, UK, Spain, India, Ukraine, and Brazil, delivering multimillion-dollar growth and transformation initiatives across many industries, including pharmaceutical research and academic literature analysis. Sam’s driving passions are solving problems, delivering software, and helping people find their place in the world and hone their true capabilities. Sam loves delivering interesting and innovative tech solutions, such as in the early days using the Netflix stack, Cassandra, and ElasticSearch, finding ways to creatively migrate technology to AWS, or building voice-based mobile applications to connect the world’s knowledge. Sam loves running, hiking, and spending time with his family and kids, fitting in video games when time permits. Sam currently serves as the architecture and consumer engineering lead of a FinTech company based in the Bay Area

About the Tech Reviewer

Garen Mnatsakanov is a Director of Engineering at a FinTech company in the Bay Area. He holds two degrees B.S. in Computer Information Systems and Business Administration. Garen has worked in most areas of technology organization: development, testing, DevOps infrastructure, product, and design. He still stays hands-on and codes. Garen has experience building strong product engineering teams and a passion for fighting complexity, classical monoliths, and distributed monoliths at scale in the cloud.

About the repository

Code samples here are mainly in Java.

Disclaimer

You won't find a complete application end-2-end here. The code samples are a way to explain, patterns and anti-patterns in the sense of design and architecture. There is no goal to have a fully functional application or service whatsoever.