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

Scale Your Application

So far, we have seen how Serverless systems are designed, implemented, monitored, and secured. In this chapter, we will look at how Serverless systems can be scaled. Scalability is often associated with the ability of a system to withstand a high load seamlessly. While this is true, the scalability of Serverless systems often encompasses a lot more.

Serverless systems typically consist of ephemeral functions and third-party services. The notion of state is almost nonexistent and hence statelessness is a key attribute of constituent functions of a Serverless system. The surface area and the responsibility of these functions are very minimal and should strictly adhere to the single-responsibility principle. Systems powered by serverless architectures consist of hundreds of nanoservices (typically an ephemeral function), each doing one job and doing it well...