Book Image

Hands-On Serverless Applications with Kotlin

By : Hardik Trivedi, Ameya Kulkarni
Book Image

Hands-On Serverless Applications with Kotlin

By: Hardik Trivedi, Ameya Kulkarni

Overview of this book

Serverless is a cloud computing execution model where the cloud provider dynamically manages the allocation and provisioning of servers. Many companies now use serverless architectures to cut costs and improve scalability. Thanks to its concise and expressive syntax and a smooth learning curve, Kotlin is a great fit for developing serverless applications. With this book, you’ll be able to put your knowledge to work by implementing serverless technology in your applications and become productive in no time. Complete with detailed explanation of essential concepts and examples, this book will help you understand the serverless architecture fundamentals and how to design serverless architectures for your applications. You’ll also explore how AWS Lambda functions work. The book will guide you in designing, building, securing, and deploying your application to production, along with implementing non-functional requirements such as auditing and logging. Furthermore, you’ll discover how to scale up and orchestrate serverless applications using an open source framework and handle distributed serverless systems in production. By the end of the book, you’ll be able to build scalable and cost-efficient Kotlin applications with a serverless framework.
Table of Contents (11 chapters)
3
Designing a Kotlin Serverless Application

Infrastructure as code

Due to the microservice/nanoservice architecture of the component functions, the code for a Serverless system is very modular. These modular components need to be decoupled from the environments they run on so that they can be deployed on demand. Further, these environments also need to be created, scaled up and out, and disposed of on demand. This dynamic cloud-native nature is impossible to manage by hand. Automation has to be the name of the game.

Infrastructure as Code (IaC) is a technique that is used to model, provision, and manage the infrastructure of cloud systems with code. With automated infrastructure management, human intervention is reduced almost entirely. So, IaC provides speed, security, precision, and most importantly reproducibility while managing environments.

As we saw in Chapter 1, Basics of Serverless, there are multiple tooling options...