This presentation discusses serverless patterns and best practices in AWS. It defines what serverless computing is and outlines the business case for serverless, including faster time to market, reduced costs, improved reliability, and increased innovation. It then covers AWS serverless design patterns and solutions, serverless myths and anti-patterns to avoid, and best practices like using the Serverless Application Model, AWS CDK, nested stacks, managing limits and connections, and power tuning.
Stephen Liedig: Building Serverless Backends with AWS Lambda and API GatewaySteve Androulakis
油
Stephen Liedig (Amazon Web Services) is a Public Sector Solutions Architect at AWS working closely with local and state governments, educational institutions, and non-profit organisations across Australia and New Zealand to design, and deliver, highly secure, scalable, reliable and fault-tolerant architectures in the AWS Cloud while sharing best practices and current trends, with a specific focus on DevOps, messaging, and serverless technologies.
Machine learning at scale with aws sage makerPhilipBasford
油
The document discusses machine learning at scale using serverless architectures on AWS, including a reference architecture using Amazon SageMaker, AWS Lambda, and other services, and details of experiments conducted to test performance, scalability, and operational aspects of deploying machine learning models with a serverless approach. It also covers monitoring metrics, deployment strategies, and using AWS services like X-Ray, CloudWatch, and CodePipeline to enable continuous deployment of machine learning models.
The document discusses three ways to serve machine learning models: AWS Fargate, AWS SageMaker endpoints and batch transforms, and AWS Lambda.
AWS Fargate supports batch and real-time inference, has low latency (<100ms), supports CPU but not GPU, charges per hour, and auto-scales applications. However, it does not integrate with SageMaker notebooks and does not support model monitoring.
AWS SageMaker supports batch and real-time inference, has built-in algorithms and frameworks, low latency (<100ms), supports CPU and GPU, charges per hour with savings plans, integrates with SageMaker notebooks, and supports model monitoring.
AWS Lambda supports only real-time or micro-batch
Serverless on AWS : Understanding the hard parts at Froscon 2019Vadym Kazulkin
油
In unserem Vortrag tauchen wir tiefer in die Serverless-Welt ein und zeigen wie eine produktionsreife Serverless-Anwendung mithilfe von AWS-Cloud mit dem Technologie-Stack API Gateway, SNS, Lambda and DynamoDB aufgebaut werden kann. Dabei gehen wir auf die Herausforderungen der jeweiligen Services ein, wie "cold start" bei Lamda oder "provisioned throughput" und "adaptice capacity" bei DynamoDB. Dabei zeigen wir, welche Strategien und Wege es gibt, damit umzugehen. Auerdem behandeln wir solche Themen wie Implementierung von Aggregationslogik und (Scheduled) Auto Scaling bei DynamoDB. Am Ende werfen wir einen Blick in die Zukunft und sprechen 端ber die erste relationale serverless Datenbank "Aurora Serverless"
Your easy move to serverless computing and radically simplified data processinggvernik
油
- PyWren-IBM is a Python framework that allows users to easily scale Python code across serverless platforms like IBM Cloud Functions without having to learn the underlying storage or function as a service APIs.
- It addresses challenges like how to integrate existing applications and workflows with serverless computing, how to process large datasets without becoming a storage expert, and how to scale code without major disruptions.
- The document discusses use cases for PyWren-IBM like Monte Carlo simulations, protein folding, and stock price prediction that demonstrate how it can be used for high performance computing workloads.
Everything fails all the time! A quote repeated by many everyday. How does it feel when things fail in production? How do you recover from such situations? How can you make sure they dont repeat? All these discussed with real production incidents and the measures taken to mitigate such failures. We will also look at few of the most common failure possibilities in a serverless ecosystem.
Remember, when everything fails all the time, you must learn something everyday to be operational all the time!
GPU Renderfarm with Integrated Asset Management & Production System (AMPS)Budianto Tandianus
油
This document describes a GPU renderfarm system integrated with an asset management and production system (AMPS) to efficiently manage rendering assets and accelerate the rendering process for CG movie production. The system allows artists around the world to upload and manage assets through AMPS. Rendering jobs are submitted online to a GPU renderfarm and monitored. Experiments showed nearly linear speedups from adding more GPU nodes, with render time decreasing from over 5 hours on one GPU to under 1.5 hours on two nodes with six GPUs total. Future work includes direct job submission from authoring tools and support for more tools, renderers, and heterogeneous renderfarm configurations.
1. The document discusses using a serverless architecture to build a reservation itinerary application for a hospitality group managing 7500 properties worldwide.
2. Key parts of the serverless solution include using AWS Lambda, Kinesis, DynamoDB, API Gateway and other services to process reservation data from multiple sources and expose APIs for mobile and web clients.
3. Challenges in the serverless implementation included unpredictable logging in CloudWatch, performance issues with Java SDK and DOM parsers, and ensuring data consistency when storing logs in DynamoDB. These were addressed through alternative approaches.
Serverless design considerations for Cloud Native workloadsTensult
油
We have built a news website with more than a billion views per month and we are sharing the learnings from that experience covering Serverless architectures, Design considerations, and Gotchas.
Getting Started with AWS Lambda & Serverless CloudIan Massingham
油
This document provides an overview of serverless computing using AWS Lambda. It defines serverless computing as running code without servers by paying only for the compute time consumed. AWS Lambda allows triggering functions from events or APIs which makes it easy to build scalable back-ends, perform data processing, and integrate systems. Recent updates include support for Python, scheduled functions, VPC access, and versioning. The document demonstrates using Lambda for building serverless web apps and microservices.
If you could not be one of the 60,000+ in attendance at Amazon AWS re:Invent, the yearly Amazon Cloud Conference, get the 411 on what major announcements that were made in Las Vegas. This presentation covers new AWS services & products, exciting announcements, and updated features.
Serverless computing is an emerging cloud computing model where the cloud provider manages resources and scales applications automatically in response to demand. With serverless, developers focus on writing code for independent, stateless functions rather than worrying about servers. Serverless platforms support automatic scaling, pay-per-use pricing, and event-driven computing using functions as the basic unit. While serverless offers benefits like reduced costs and management overhead, it also presents drawbacks like vendor lock-in and lack of debugging access.
What is AWS?
Most Popular AWS Products
What is Serverless Architecture?
Asynchronous Serverless Model
Synchronous Serverless Model
Amazon Lambda
https://notebookbft.wordpress.com/
Gluecon 2018 - The Best Practices and Hard Lessons Learned of Serverless Appl...Chris Munns
油
In November 2014, AWS Lambda introduced developers to serverless compute with automatic scaling, pay-per-request billing, and built-in high availability. As a result, startups and enterprises are changing the way they build their applications. Since then, we've learned a lot from our customers about what it takes to build successful serverless applications. Weve also seen some common and not so common missteps that developers building serverless applications have made along the way. Today, we're going to share those learnings, and show you how you can build the best serverless application that you can.
RightScale Webinar: Operationalize Your Enterprise AWS Usage Through an IT Ve...RightScale
油
Weve all seen the trend everywhere around us: customers want self-service. It offers them the agility they need and gives businesses the ability to scale and lower their costs. With cloud deployments, enterprises can experience similar benefits through the use of a self-service portal where internal customers can provision their own resources while Central IT maintains control and visibility. This saves both time and money.
In this webinar, learn how to empower your internal customers to provision the necessary cloud resources when they need them but also ensure that what get receive is well within IT approved guidelines. Beyond simple convenience, this methodology permits you to operationalize your AWS cloud usage to easily roll cloud into an overall IT strategy.
Architects from Amazon Web Services (AWS) and RightScale, an Advanced Technology Partner, will provide an overview of the key business and technical considerations for operationalizing your AWS cloud usage. In the second half of the webinar, our technical experts will answer your questions. Priority will be given to pre-submitted questions.
To help illustrate the effectiveness of this approach, our architects will walk you through real-world examples and the overall impact on their organizations.
Key Topics:
1. Create an IT Vending machine with consistent and reproducible processes.
2. Enable your end users while maintaining visibility and control.
3. Use cost planning and forecasting to fine-tune and understand cloud spend.
4. Discover reporting and auditing tools to ensure compliance.
5. Avoid downtime through proven HA/DR architectures.
12 Factor Serverless Applications - Mike Morain, AWS - Cloud Native Day Tel A...Cloud Native Day Tel Aviv
油
The Twelve-Factor application model has come to represent twelve best practices for building modern, cloud-native applications. With guidance on things like configuration, deployment, runtime, and multiple service communication, the Twelve-Factor model prescribes best practices that apply to everything from web applications to APIs to data processing applications. Although Serverless computing and AWS Lambda have changed how application development is done, the Twelve-Factor best practices remain relevant and applicable in a Serverless world. In this talk, well apply the Twelve-Factor model to Serverless application development with AWS Lambda and Amazon API Gateway and show you how these services enable you to build scalable, low cost, and low administration applications.
GOTO Stockholm - AWS Lambda - Logic in the cloud without a back-endIan Massingham
油
際際滷s from my session at Goto Stockholm where I talked about AWS Lambda and how it can be used to build reliable, scalable & low-cost applications, without servers for you to manage.
Special thanks to James Hall at Parallax for allowing me to talk about the awesome application that they built using AWS Lambda, Amazon API Gateway & Amazon DynanmoDB :)
Introduction To Serverless ArchitectureBen Sherman
油
Ben Sherman is a software engineer and founder of Plator Solutions, an AWS consulting firm. He has a computer engineering degree and previously worked at Amazon. The document defines serverless architecture as cloud-hosted backend services and event-triggered functions that are fully managed, allowing developers to focus on business logic without managing infrastructure. Key benefits of serverless include cost savings due to paying only for resources used, seamless scalability without capacity planning, and faster development without backend provisioning and management.
1. The document discusses using a serverless architecture to build a reservation itinerary application for a hospitality group managing 7500 properties worldwide.
2. Key parts of the serverless solution include using AWS Lambda, Kinesis, DynamoDB, API Gateway and other services to process reservation data from multiple sources and expose APIs for mobile and web clients.
3. Challenges in the serverless implementation included unpredictable logging in CloudWatch, performance issues with Java SDK and DOM parsers, and ensuring data consistency when storing logs in DynamoDB. These were addressed through alternative approaches.
Serverless design considerations for Cloud Native workloadsTensult
油
We have built a news website with more than a billion views per month and we are sharing the learnings from that experience covering Serverless architectures, Design considerations, and Gotchas.
Getting Started with AWS Lambda & Serverless CloudIan Massingham
油
This document provides an overview of serverless computing using AWS Lambda. It defines serverless computing as running code without servers by paying only for the compute time consumed. AWS Lambda allows triggering functions from events or APIs which makes it easy to build scalable back-ends, perform data processing, and integrate systems. Recent updates include support for Python, scheduled functions, VPC access, and versioning. The document demonstrates using Lambda for building serverless web apps and microservices.
If you could not be one of the 60,000+ in attendance at Amazon AWS re:Invent, the yearly Amazon Cloud Conference, get the 411 on what major announcements that were made in Las Vegas. This presentation covers new AWS services & products, exciting announcements, and updated features.
Serverless computing is an emerging cloud computing model where the cloud provider manages resources and scales applications automatically in response to demand. With serverless, developers focus on writing code for independent, stateless functions rather than worrying about servers. Serverless platforms support automatic scaling, pay-per-use pricing, and event-driven computing using functions as the basic unit. While serverless offers benefits like reduced costs and management overhead, it also presents drawbacks like vendor lock-in and lack of debugging access.
What is AWS?
Most Popular AWS Products
What is Serverless Architecture?
Asynchronous Serverless Model
Synchronous Serverless Model
Amazon Lambda
https://notebookbft.wordpress.com/
Gluecon 2018 - The Best Practices and Hard Lessons Learned of Serverless Appl...Chris Munns
油
In November 2014, AWS Lambda introduced developers to serverless compute with automatic scaling, pay-per-request billing, and built-in high availability. As a result, startups and enterprises are changing the way they build their applications. Since then, we've learned a lot from our customers about what it takes to build successful serverless applications. Weve also seen some common and not so common missteps that developers building serverless applications have made along the way. Today, we're going to share those learnings, and show you how you can build the best serverless application that you can.
RightScale Webinar: Operationalize Your Enterprise AWS Usage Through an IT Ve...RightScale
油
Weve all seen the trend everywhere around us: customers want self-service. It offers them the agility they need and gives businesses the ability to scale and lower their costs. With cloud deployments, enterprises can experience similar benefits through the use of a self-service portal where internal customers can provision their own resources while Central IT maintains control and visibility. This saves both time and money.
In this webinar, learn how to empower your internal customers to provision the necessary cloud resources when they need them but also ensure that what get receive is well within IT approved guidelines. Beyond simple convenience, this methodology permits you to operationalize your AWS cloud usage to easily roll cloud into an overall IT strategy.
Architects from Amazon Web Services (AWS) and RightScale, an Advanced Technology Partner, will provide an overview of the key business and technical considerations for operationalizing your AWS cloud usage. In the second half of the webinar, our technical experts will answer your questions. Priority will be given to pre-submitted questions.
To help illustrate the effectiveness of this approach, our architects will walk you through real-world examples and the overall impact on their organizations.
Key Topics:
1. Create an IT Vending machine with consistent and reproducible processes.
2. Enable your end users while maintaining visibility and control.
3. Use cost planning and forecasting to fine-tune and understand cloud spend.
4. Discover reporting and auditing tools to ensure compliance.
5. Avoid downtime through proven HA/DR architectures.
12 Factor Serverless Applications - Mike Morain, AWS - Cloud Native Day Tel A...Cloud Native Day Tel Aviv
油
The Twelve-Factor application model has come to represent twelve best practices for building modern, cloud-native applications. With guidance on things like configuration, deployment, runtime, and multiple service communication, the Twelve-Factor model prescribes best practices that apply to everything from web applications to APIs to data processing applications. Although Serverless computing and AWS Lambda have changed how application development is done, the Twelve-Factor best practices remain relevant and applicable in a Serverless world. In this talk, well apply the Twelve-Factor model to Serverless application development with AWS Lambda and Amazon API Gateway and show you how these services enable you to build scalable, low cost, and low administration applications.
GOTO Stockholm - AWS Lambda - Logic in the cloud without a back-endIan Massingham
油
際際滷s from my session at Goto Stockholm where I talked about AWS Lambda and how it can be used to build reliable, scalable & low-cost applications, without servers for you to manage.
Special thanks to James Hall at Parallax for allowing me to talk about the awesome application that they built using AWS Lambda, Amazon API Gateway & Amazon DynanmoDB :)
Introduction To Serverless ArchitectureBen Sherman
油
Ben Sherman is a software engineer and founder of Plator Solutions, an AWS consulting firm. He has a computer engineering degree and previously worked at Amazon. The document defines serverless architecture as cloud-hosted backend services and event-triggered functions that are fully managed, allowing developers to focus on business logic without managing infrastructure. Key benefits of serverless include cost savings due to paying only for resources used, seamless scalability without capacity planning, and faster development without backend provisioning and management.
Play-it-Forward: A Sustainable Sports-Initiative in Zambiarenubharathi99
油
This presentation explores Play it Forward, a project to build a sustainable sports facility in Zambia. It focuses on community development, financial planning, funding strategies, and long-term sustainability. Key aspects include stakeholder engagement, income diversification, and strategic partnerships to ensure success.
2. This presentation has been prepared by EPAM Systems, Inc. solely for use by EPAM at its EPAM Zed
Conference. This presentation or the information contained herein may not be reproduced or used
for any other purpose. This presentation includes highly confidential and proprietary information and
is delivered on the express condition that such information will not be disclosed to anyone except
persons in the recipient organization who have a need to know solely for the purpose described
above. No copies of this presentation will be made, and no other distribution will be made, without
the consent of EPAM. Any distribution of this presentation to any other person, in whole or in part,
or the reproduction of this presentation, or the divulgence of any of its contents is unauthorized.
CONFIDENTIAL INFORMATION
4. What Serverless Is
Serverless computing is a cloud computing execution model in which the cloud provider
allocates machine resources on demand, taking care of the servers on behalf of their customers
息 Wikipedia https://en.wikipedia.org/wiki/Serverless_computing
6. Focus on business value, not infrastructure
1. F A S T E R T I M E T O M A R K E T
2.
3.
R E D U C E D C O S T S
I M P R O V E D R E L I A B I L I T Y
6
4. I N C R E A S E D R AT E O F I N N O VAT I O N
7. Faster time to market
By eliminating operational overhead, your teams can release quickly, get
feedback, and iterate to get to market faster.
8. Reduced costs
With a pay-for-value billing model, you never pay for over-provisioning and
your resource utilization is optimized on your behalf.
10. Increased rate of innovation
Serverless applications have built-in service integrations, so you can focus on
building your application instead of configuring it.
12. AWS Lambda/Serverless patterns overview
AWS designed many solutions, and you should just find building
blocks for your cases
Web application
Mobile application for social distancing
Mobile back-end
Real-time stream processing
IoT back-end
AWS Connected mobility architecture
Real-time file processing
MapReduce
Image recognition & processing
Image moderator chatbot
12
https://aws.amazon.com/lambda/resources/reference-architectures/
17. Myths
Myth #1: Serverless means no server and hardware
You need to setup required RAM size
Myth #2: Serverless == Lambda (AWS Lambda, Azure Functions etc.)
Amazon enumerates as serverless such services as S3, SQS, SNS, API Gateway, DynamoDB
Myth #3: Serverless is cheap, definitely cheaper than serverfull solution
Not always, you always should calculate costs ahead to see if its good fit
18. Going Stateful Anti-Pattern
Antipattern #1: Going stateful (in-memory state)
Problem
Though lambda instance can be preserved for the next requests (such called
hot start), it is not guaranteed
After lambda run, lambda instance can be terminated anytime
Solution
You need a state, store it in external services
18
19. Do Not Pay Attention To Service Specifics
Antipattern #2: Do not pay attention to service specifics
Problem
I just write my code and deploy it to AWS Lambda and everything works right, but only if
you agree with terms of service. AWS Lambda for example, have number of limitations (quotas):
Request size <= 6Mb (so you cannot use it for file upload, use S3 for that)
Max execution time is 15 minutes (lambda is terminated by timeout then)
Solution
Regularly revisit quotas, know your data, check if they fit
Remember there are hard and soft limits, soft limits can be increased on request
19
20. My Favorite Stack Is Great At Lambdas
Antipattern #3: Use your favorite tech stack without paying attention at cost
Problem
Startup can be much slower in comparison to using plain old java or another language
You are charged on a second basis.
Reducing overall duration from 10 seconds to 5 seconds will cut your costs twice
Decreasing memory size (because code in Java was rewritten in Go) by two times will cut your costs
twice
Solution
As lambda should be small, you can write it in Go/Python/JavaScript even if you are not a Pro in this
language
So the pattern is: consider if the cost benefit worth learning
20
21. Multithreading Is Great In Lambdas
Antipattern #4: Using old-fashioned way for orchestration
Problem
I will save a record in DynamoDB from lambda
and then Thread.sleep for another service to update its status
Each second if lambda does not do anything, you still pay money
Avoid explicit and try to avoid implicit waits
Implicit wait blocking lambda instance awaiting for response from synchronous calls (RESTs)
Explicit wait Thread.sleep, polling messages from queues in while loops, checking state in while loops
etc.
Solution
Orchestration using AWS Step Functions
Choreography using message brokers (SQS, EventBridge, Kinesis, DynamoDB Streams)
21
23. Serverless Application Model
Build serverless applications in simple and clean syntax
Features:
Built on AWS CloudFormation
Built-In Best Practices
Single Deployment Configuration
Local Testing and Debugging
(+ https://localstack.cloud/)
Serverless Application Model - https://aws.amazon.com/serverless/sam/
25. Nested Stacks
Nested stacks are stacks created as part of other stacks.
Nested stacks can themselves contain other nested stacks, resulting in a
hierarchy of stacks, as in the diagram below. The root stack is the top-
level stack to which all the nested stacks ultimately belong. In addition,
each nested stack has an immediate parent stack. For the first level of
nested stacks, the root stack is also the parent stack. in the diagram
below, for example:
Stack A is the root stack for all the other, nested, stacks in the hierarchy.
For stack B, stack A is both the parent stack, and the root stack.
For stack D, stack C is the parent stack; while for stack C, stack B is the
parent stack.
https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/using-
cfn-nested-stacks.html
26. Know Your Limits
Lambdas executions
Concurrent executions - 1,000
Step Functions
Maximum number of registered state machines - 10,000
Maximum open executions per account - 1,000,000 executions
per AWS account.
ENIs for Lambdas are not endless
Elastic network interfaces per virtual private cloud (VPC) - 250
Limit on S3 buckets for Lambdas
Buckets - 100 per account
27. AWS Lambda Power Tuning
AWS Lambda Power Tuning is a state machine powered by AWS Step Functions that helps you optimize your Lambda functions for cost
and/or performance in a data-driven way.
https://github.com/alexcasalboni/aws-lambda-power-tuning
28. DB Connections Management
Serverless works best with services rather than connections.
Connection management:
Application connection pooling
RDS Proxy
Amazon Aurora Serverless v2
Data API
Dynamo DB
https://aws.amazon.com/blogs/database/best-practices-for-working-
with-amazon-aurora-serverless/
29. Thank you!
For more information, contact
Dima Pasko
Solution Architect II
Dmytro_Pasko@epam.com
https://www.linkedin.com/in/dimapasko
#3: Based on real life experience in Insurance domain
#4: Kharkiv, Ukraine
Solution Architect
Passionate and successful Architect with over 17 years of experience including 6 years of experience in Software Architecture
Experience in Digital Transformation projects with Microservices & Serverless
Multi-cloud experience: AWS, Azure
#5: Next evolution of cloud computing.
Serverless <> not only lambda, it is serverless DBs Engines, Container services, BPMN engines.
Servers not have gone you do not manage them only.
#8: Faster time to market
(Business logic > API) >Messaging & Orchestration -> Storage & Databases -> Compute -> Physical Infrastructure
AWS Lambda automatically runs your code without requiring you to provision or manage infrastructure. Just write the code and upload it to Lambda either as a ZIP file or container image.
Focus on most important part of your application
Technology abstraction allows us to focus on building just the pieces of code and configuration that are providing truly unique value for the client.
Productive for the day one
#9: Cost optimized with millisecond metering
With AWS Lambda, you only pay for the compute time you consume, so youre never paying for over-provisioned infrastructure. You are charged for every millisecond your code executes and the number of times your code is triggered.
At its most basic, the cost case for serverless boils down to utilization. Youve probably seen the numbers traditional, on-premise datacenter servers tend to be only 15 to 30% utilized. (Weve even heard that most large EC2 users struggle to reach this utilization rate as well!) Put the other way, that means 70 to 85% of your server costs are dead weight. Waste.
仆舒仍仂亞亳 舒弍仂仆亠仄亠仆 于 仗仂亰舒仍亠
No hidden costs:
Security
Platform outdated
(personal story) test environment for 18 teams ~ $400
#10: Scale from zero to infinity and back
Consistent performance at any scale(smooths)
With AWS Lambda, you can optimize your code execution time by choosing the right memory size for your function. You can also keep your functions initialized and hyper-ready to respond within double digit milliseconds by enabling Provisioned Concurrency.
#11: Easy to start new project, very cheap, modularity, elasticity
Experiments, new environment, iteration cycle
A lot of integrations. Event based. Out of the box.
Architecture improvement: breaking the monolith into functions that could be independently deployed, meant that they were better able to split the team up to work on more things in parallel, and to deploy each feature separately
Next evolution of cloud computing.
Continuously improving: ARM + Graviton
#13: Dont invent a wheel and review AWS resources
Try to search and adopt existing to your case
Also this is a good reason to learn how to draw diagrams for AWS
#14: AWS Well-Architected Framework
The AWS Well-Architected Framework Lens provides a set of foundational questions for you to consider for all of your cloud architectures.
Serverless Lens
Description
The AWS Serverless Application Lens provides a set of additional questions for you to consider for your serverless applications.
#15: Tell how you open AWS console, add workload, grouped questions, download a report
#16: Tell how you open AWS console, add workload, grouped questions, download a report
#18: Serverless can gain polarized opinion starting from use it everywhere, its cool! to just a hype, Im good with my Java 5 + tomcatAnd this emotional attitude often drives technology selection
Thats why this slide is more about myths about serverless than about antipatterns
Myth #1: Serverless means no server and hardware Servers not have gone you do not manage them only.
And sometimes this abstraction leaks for lambda you need to setup required RAM size
Serverless more means no infrastructure work all the infrastructure maintenance is on provider
Portability, Vendor lock
Myth #2: Serverless == Lambda (AWS Lambda, Azure Functions etc.)
As Serverless means no infrastructure work, many of services familiar to you are already serverless. AWS S3 for example.
Amazon enumerates as serverless such services as S3, SQS, SNS, API Gateway, DynamoDB
Even modification of Aurora falls into this category
Myth #3: Serverless is cheap, definitely cheaper than serverfull solution
Not always, you always should calculate costs ahead to see if its good fit
Not all workloads are suitable for serverless
Example from Insurance domain, predictable loadAd tech, stock exchange could bad domain example
#19: The Sirens & Odysseus
Antipattern #1: Going stateful (in-memory state)
We are not talking about state saved in external service (caches like Redis, databases etc) that approach is fine
But accumulating in-memory state is definitely antipattern:
Though lambda instance can be preserved for the next requests (such called hot start), it is not guaranteed
After lambda run, lambda instance can be terminated anytime
So the pattern is: if you need a state, store it in external services. For fast access use distributed caches as AWS ElastiCache (managed Redis)
You CAN go with in-memory state if you know what you are doing (lambdas are in warm state, have provisioned/reserved concurrency on so instances will likely be reused)
#21: Myth of Jason and the Argonauts
Antipattern #3: Use your favorite tech stack without paying attention at cost
I will write this on Spring Boot can have such downsides:
You might need more memory for lambda than for the same logic written in Go or Python (up to 4 times and more)
Startup can be much slower in comparison to using plain old java or another language
Can be mitigated by keeping lambda at warm state for hot start
Often for cold start the startup time can be longer than processing time itself
Both memory size and startup time add a cost
You are charged on a second basis. Reducing overall duration from 10 seconds to 5 seconds will cut your costs twice
Decreasing memory size (because code in Java was rewritten in Go) by two times will cut your costs twice
As lambda should be small, you can write it in Go/Python/JavaScript even if you are not a Pro in this language
So the pattern is: consider if the cost benefit worth learning a bit of Python
No Dependency Injection frameworks?
#22: King Midas and his touch
Antipattern #4: Using old-fashioned way for orchestration
I will save a record in DynamoDB from lambda and then Thread.sleep for another service to update its status
Each second if lambda does not do anything, you still pay money
Design for retries
So the pattern is:
Avoid explicit and try to avoid implicit waits
Implicit wait blocking lambda instance awaiting for response from synchronous calls (RESTs)
Explicit wait Thread.sleep, polling messages from queues in while loops, checking state in while loops etc.
Use Cloud-Native way of logic organization:
Orchestration using AWS Step Functions
choreography using message brokers (SQS, EventBridge, Kinesis, DynamoDB Streams)
#26: Nested Stacks
Monorepo one repo for workload
Good to keep order, atomic deployments, PR in one repo, easier engennering best practices
#27: 11. AWS Account strategy (Sizing (Account per Team), sharing resources, hard to performance test, limits)
a. See Laura's Blog for some details on Lambda Concurrency issues :https://myconnections.lmig.com/blogs/n0085283/2019/03/14/aws-lambdas-setting-a-max-concurrency-its-consequences
Best practices: - Dashboards
Alerts, Notifications
Sets of best practices