Serverless Architectures on AWS
Serverless is made for event-driven architectures. Dividing your app into functions and making use of microservices architecture are keys to success in the cloud.
Join the DZone community and get the full member experience.Join For Free
A serverless platform allows you to run your application—including computing, storing, and networking —without the need for spinning up and managing a single (virtual) machine. This article focuses on serverless architectures on AWS including Lambda, API Gateway, DynamoDB, S3, and more. The architecture patterns can be transferred to other cloud platforms as well.
Being able to focus on software development instead of operating a fleet of servers is the primary driver behind serverless. Alternatively, as Werner Vogels, CTO of Amazon.com, says: “No server is easier to manage than no server.” Another important aspect of serverless infrastructure is finely granular billing and extreme scalability. To give you an impression of typical use cases, here are some serverless applications I have been working on recently:
- Collecting metrics from web application with a REST API in a high load scenario.
- Extracting and storing data from incoming emails containing order and status information.
- Creating a REST API providing a standard CRUD backend.
- Collecting and transforming data within an ETL process in a big data scenario.
- Analyzing log messages from a real-time data stream.
- Building a chatbot that is interacting with multiple APIs in the background.
Dividing your application into small functions is necessary when following a serverless approach. Making use of microservice architectures helps you to achieve that goal. Serverless is made for event-driven architectures. An event is a source for triggering a serverless function and the glue when orchestrating multiple serverless functions forming a system.
Triggering a function with AWS Lambda is possible based on the following events:
- Incoming HTTPS request.
- Changing data stored in a database or object storage.
- Incoming message (e.g. email).
- Publishing a task to a topic or real-time data stream.
- Scheduled event (comparable with a cronjob).
Read the rest of this article and a lot more in:
- Industry Research Data
- Articles Written by Industry Experts
- Cloud Architecture Infographic
- Directory of the Best Tools & Solutions
Opinions expressed by DZone contributors are their own.