So far in this book, the discussion about the motivations and principles behind cloud native technologies addressed the why and what. Now, let’s dive into the how. This chapter introduces the techniques, tools, and technologies that make the cloud native approach possible, specifically in the context of Google Cloud.
Autonomous Components Communicating with Messages
Alan Kay, a prominent computer scientist primarily known for pioneering object-oriented programming and the development of the Smalltalk programming language in the 1970s, envisioned computer software as akin to a biological system constituted of interlinked cells. His model fosters a mindset that promotes application modularity and reusability.
The cornerstone of Kay’s concept is messaging, a mechanism that allows application cells to communicate with each other. Unlike traditional methods that rely on a shared state, messaging ensures interaction through sending and receiving of information. Essentially, Kay advocated for a world of autonomous components, interacting seamlessly through messages.
Interestingly, cloud native applications share striking parallels with Alan Kay’s vision, principally the attribute of loosely coupled components. This idea, in itself, is not novel. However, the innovation lies in the amalgamation of contemporary tools, techniques, and technologies that create a robust toolkit for building cloud native applications. Let’s explore this in detail, shedding light on how such elements blend to architect modern, efficient, and scalable applications in the cloud.
Harnessing Cloud Potential with the 12-Factor App Principles
Heroku, a cloud platform service established in 2007, quickly became a favorite among developers. It offered an effortless environment for hosting applications, a haven that provided support right from the development phase to secure deployment, albeit within the platform’s specific constraints. Many of today’s cloud native platforms, including Google Cloud, strive to emulate this developer-friendly experience while minimizing limitations.
In 2012, after extensive engagement with their customers, Adam Wyner and his team at Heroku began to recognize common patterns among applications that performed exceptionally well on their platform. This observation led to the consolidation of these patterns into a cohesive set of guidelines and best practices for developing cloud native applications, known as the 12-factor app principles.
The 12-factor app principles found extensive application in Cloud Foundry, another platform inspired by Heroku. As cloud platforms continue to evolve, these principles have proven enduring, gaining widespread acceptance as a comprehensive blueprint for designing cloud-ready software.
If you’re interviewing for a cloud native developer position, it’s likely the concept of 12-factor applications will emerge as a foundational topic. While many candidates might recollect some of the factors’ names, similar to recalling catchy acronyms like SOLID or DRY, understanding the underlying concept is far more critical. You should comprehend the problem each factor addresses and how to practically implement them.
Moreover, it’s worth noting that the 12-factor app principles were originally devised with a specific platform in mind. Therefore, it’s essential to revisit these principles in that original context before applying them to Google Cloud, to ensure their most effective use and relevance.