August 19, 2020

10 approaches to control and reduce AWS costs

Jump to sections
Spending made smarter
Easy-to-use cards, spend limits, approval flows, vendor payments —plus an average savings of 3.5%.
Get fresh finance insights, monthly
Time and money-saving tips,
straight to your inbox
Thanks for signing up
Oops! Something went wrong while submitting the form.

Cloud costs from Amazon Web Services (AWS) can add up quickly for large businesses, but there are cost management tricks & techniques you can employ to save money. The suggestions below can help with AWS cost optimization. Many of the recommendations are applicable to other cloud providers, such as Google Cloud and Microsoft Azure, too.

1. S3 versioning and EBS/RDS snapshots

AWS makes it easy to amass immense amounts of historical data, through Amazon S3 versioning, RDS snapshots and EBS Lifecycle Manager. Keeping a few backups is always a good idea, but careful planning is needed to ensure storage costs don’t grow linearly. Lifecycle policies for S3, ECR and EBS are invaluable and can also be used to change storage tiers (i.e., Glacier for S3). For more complex logic, one can configure a regularly invoked Lambda function to explicitly clean up old data. This function can also be used to replicate RDS snapshots across regions for regional resiliency.

2. General-purpose instance classes

When choosing an instance class for ElastiCache, RDS, EC2 or other AWS services, it is tempting to opt for a compute or memory-optimized variant. By and large, these are orders of magnitude more expensive than general-purposes t3.XXX sizes and aren’t needed unless you have specific requirements. AWS’ concept of burstable CPU, governed by CPU credits, works well for the majority of use cases. Using the latest generation of instance type always gets the most performance in a more cost-effective way.

3. Savings plans

Reserved Instances, whereby one makes a 1-year or 3-year commitment for a particular AWS service at a negotiated rate, have been around for a while. In their current incarnation, you can switch between instance classes easily. Savings Plans allow for a broader commitment to a collection of AWS services (namely EC2, Fargate and Lambda), providing more flexibility. Take note to only purchase any commitment as a last resort, after you have already optimized and reduced your environmental footprint as much as possible.

4. RDS multi-AZ and replicas

Enabling multi-AZ for RDS instances or adding an additional instance to an Aurora RDS cluster immediately doubles your costs. This should only be done in production environments where you need the resiliency or extra performance of a read-replica.

5. Resizing ECS task definitions

Above and beyond ECS autoscaling, where the number of tasks for a given service is adjusted using automation, consider adjusting the task definition configuration for the allocated vCPU and memory. Though there are a limited number of supported configuration permutations, lowering either vCPU or memory slightly can have large savings across multiple environments and dozens of tasks. A big advantage of using Fargate over EC2 is that one doesn’t need to worry about provisioning sufficient underlying EC2 instance capacity.

6. Share expensive services across AWS accounts

If you have multiple AWS accounts, consider joining them all to an organization. Not only does this umbrella topology make billing simpler, but it allows you to share certain services for cost-savings. Shield Advanced is priced at $3,000/month per organization and Private Certificate Authorities are $400/month but can be shared across accounts.

7. Thrashing Docker containers

If using ECS Fargate, a common unforeseen expense can be thrashing Docker containers which are failing to properly start up. The ECS service will continue to initiate a new task indefinitely. Each time, the task definition will pull the image from either ECR or Docker Hub consuming a sizeable amount of bandwidth. Over the course of a month, a single failing task can cost multiple terabytes of transfer costs. One can monitor for this with Datadog alerts or CloudWatch alarms.

8. Third-party integrations

Integrations like Datadog, Vanta and Fivetran can be overly aggressive with their sync frequency and breadth of data absorbed. This leads to high CloudWatch metric, Data Transfer and NAT Gateway charges. For each provider, ensure you have only the bare minimum of enabled features (i.e., disabling DMS in Datadog, if not using it) and a reasonable sync frequency (i.e., every 15 mins instead of every 5 mins).

9. Dovetailing services

The headline pricing for all AWS services can be deceiving. Generally priced per hour, a cost of $0.98/hour looks a lot more affordable than $729.12/month. Equations, partial hours and dimensions(i.e., LCUs on ALBs) can further complicate AWS pricing estimates.

However, the biggest hidden cost is all of the ancillary services that each AWS offering relies on. For example, using an ALB can have ‘dovetailed’ costs with CloudWatch metrics, S3 logging, DataTransfer, WAF ACLs, etc., Removing or consolidating any single AWS resource can therefore have knock-on effects to your bill.

10. Expiring credits

Many startups are fortunate enough to acquire credits with AWS, through their Ramp credit card or from the incubator they participated in. While thousands of dollars in free money is nothing to scoff at, AWS sets a finite expiry on the credits, usually 12 months later. Take a periodic look at both your remaining credit balance and the credit expiry to avoid unpleasant surprises. This can be seen under My Billing Dashboard and then Credits.

Head of Infrastructure & DevOps, Ramp

Lewis is Head of Infrastructure at Ramp and oversees several teams. He has over twenty years of experience in architecting and deploying scalable, secure, and resilient cloud infrastructure, most often within AWS. Alongside financial services, Lewis has previously run large environments in a variety of industries, including education, fashion, healthcare, media, and technology. He lives in New York City.


How Crossbeam saved $10K+ with Ramp Price Intelligence

“Right now, I text a group of colleagues and search online—but being able to know within a 5% variance that we are solid on pricing? That gives me peace of mind."
Matt Dougherty, Senior Director of Finance, Crossbeam

How Clearbit closed the books >60% faster with Ramp + NetSuite

“Before Ramp, our month-end close took approximately 10 days. Now it takes three to four days—it's unbelievable.”
Kay Coolican, Accounting Manager, Clearbit

How Ramp helped Webflow lay a foundation for sustained growth

“This product allows us to enable our employees to be full-time right away, Ramp allows us to onboard people quicker, it allows us to get them the tools they need, which in many cases they need to be able to spend in order to grow.”
Ivan Makarov

How Candid expanded internationally with Ramp

“Ramp found over $250,000 in savings right out of the gate. That is far more valuable than any points program.”
Nick Greenfield, CEO, Candid

How FirstBlood’s switch to Ramp sped up their monthly close

“If I code one transaction with a certain vendor, Ramp knows. It makes suggestions based on past transactions. It just works.”
Kyle Potter, CFO, FirstBlood

How Elementus overhauled its spend management with Ramp

“The fact that I can have an expense, match it with a receipt immediately, upload it, and then integrate it into QuickBooks is a godsend.”
Matt Austin, Vice President of Operations, Elementus

How Eight Sleep consolidated their finance stack and launched a new product with Ramp

“Identifying the invoice, finding it in Ramp Bill Pay, and flexing it from there, takes all of one minute…it’s only a few clicks and you’re done.”
Irish Rose, Controller, Eight Sleep