Book Image

Cloud Native Development Patterns and Best Practices

By : John Gilbert
Book Image

Cloud Native Development Patterns and Best Practices

By: John Gilbert

Overview of this book

Build systems that leverage the benefits of the cloud and applications faster than ever before with cloud-native development. This book focuses on architectural patterns for building highly scalable cloud-native systems. You will learn how the combination of cloud, reactive principles, devops, and automation enable teams to continuously deliver innovation with confidence. Begin by learning the core concepts that make these systems unique. You will explore foundational patterns that turn your database inside out to achieve massive scalability with cloud-native databases. You will also learn how to continuously deliver production code with confidence by shifting deployment and testing all the way to the left and implementing continuous observability in production. There's more—you will also learn how to strangle your monolith and design an evolving cloud-native system. By the end of the book, you will have the ability to create modern cloud-native systems.
Table of Contents (12 chapters)

Testing

In the previous chapter, we began our deep dive into the human factors of cloud-native. We discussed how decoupling deployment from release by controlling batch size, shifting deployment all the way to the left, and leveraging dark launches helps mitigate risk and empowers self-sufficient, full-stack teams to rapidly and continuously deliver innovation with confidence. Deliberately planned release and deployment roadmaps facilitate this decoupling. Deployments are controlled by a task branch workflow and orchestrated by a modern CI/CD pipeline to help ensure zero-downtime deployments. Testing is no longer a phase—it is an integral part of the deployment pipeline.

In this chapter, we will continue to discuss the human factors of cloud-native. We will shift testing all the way to the left and weave it into the CI/CD pipeline to help enable teams to continuously deploy...