E02 - Finding the best Devops & PaaS Platforms - AWS ECS

E02 - Finding the best Devops & PaaS Platforms - AWS ECS

Under the new series of "Devops & PaaS Platforms", I am evaluating various different platforms on how easy it is to deploy, manage and scale our software applications.

👉🏼 Previously, I wrote about Heroku - one of the first and biggest platform and what challenges did developers face on it in today's times.

What is AWS ECS?

AWS Elastic Container Service (ECS) is a container management offering by AWS, where we can deploy our applications using Docker Images and the management overhead of the containers rest with AWS.

Now, as great and easy it sounds (yes, it is an amazing product), it has it's own challenges of use, so let's see how it fares in our evaluation of Devops and PaaS platforms.

Ease of Use & Customisability

While someone who knows about AWS and ECS services in much depth, it would be very easy to create Clusters, task definitions, and deploy them for the first time. But at the same time, for anyone to start learning and deploying on AWS ECS, it has a very steep learning curve, specially when it does not a parallel analogy with Kubernetes but has it's own definitions and objects (Task Definitions, Scheduling, etc)

Again, even if we deploy easily once on ECS, we have to think about Production use cases - Having multiple environments (staging, production), access to easy logs and monitoring systems, as well as number of services we use to deploy the whole solution.

ECS does not support environments -- You will have to manage the logic of Staging/Production yourself, as different clusters or different task definitions or task files. The logs and monitoring uses Cloudwatch which is again a bare-minimum logging mechanism and we can't have traces / profiles / alerts created on application level, with no easy way o integrating ELK or Grafana/Loki systems.

You would also need to know about API Gateways, Load Balancers, ACM (for SSL), Vaults, ECR, EBS or EFS and many other services to deploy a production grade application on AWS ECS.

My Ease of Use Score - 6/10

Innovation and Growth

As ECS is an AWS managed service, they keep on integrating new things and services and add support, internally of other AWS services. So we can safely say that they do innovate but do have a very big customer lock in.

Innovation and Growth Score - 8/10

Pricing

AWS ECS has two types of Pricing Models - Fargate based and EC2 based.

In Fargate based, you don't need to spin up explicit machines or manage them, while if you need your containers / apps to be deployed on only specific machines you want to control, you can use EC2 based deployment.

Fargate Pricing ( 1 vCPU, 4GB RAM, x86 ) - $44.66 per month

Pricing Score - 8/10

Is the pricing giving you enough returns?

If you read the above sections, you will realise that there are far more cons than pros when using ECS, such as

  • Vendor Lockin
  • No support for native environments
  • Steep Learning Curve
  • Only Cloudwatch for Logs and Monitoring (Super less features)
  • Need to integrate many more AWS Services for full solution

🚨 Now as our goal was to automate our Devops, using AWS ECS would not allow us go without our Devops team involvement, and would again be a cost (& time) heavy process.

🤔 Will I choose AWS ECS as preferred deployment platform for my applications?

Preferably not, atleast not in today's time, where I have much easier, simpler tools available for my apps :)

😇 If you liked the analysis, please do Subscribe to this newsletter and give it a Like ❤️ or Repost 🔁.
Vaibhav B.

Software Engineer III @ JP Morgan, Singapore

2mo

i can relate, wasted two days to deploy my spring boot app on ecs. not very easy to understand for a backend developer.

Like
Reply
Mustafa Nazar

'Building the Future of Wealth Creation in Mutual Funds at Moneyfactory"

2mo

Very Insightful blog Shrey Batra Like you rightly mentioned, Experts are needed for AWS and they come at a steep cost, India as an economy is very large but the drivers are mostly SME and MSME, same goes for startups too, agility, costing and reliability needs to looked at from the ground up.

Like
Reply
Atul Anand

WIN Home Inspection | Sceneview Agumented Reality Member | Ex Flam | Google open source contributor |

2mo

Hi Shrey Batra great blog! I did notice that you mainly highlight the disadvantages of ECS, but in my experience with both Kubernetes and ECS, I find ECS offers a lot of robust features. For instance, AWS Parameter Store is perfect for managing secret keys, and it’s easy to set up dashboards and alerts for key metrics like CPU usage. I’m curious why you suggest using Vault or other external services with ECS when AWS provides cost-effective solutions like Parameter Store and ALB. ECS also has a very low learning curve—you can deploy production-grade applications in just a day. Plus, it offers flexible deployment strategies like blue/green and rolling updates. If I had to compare the complexity, Kubernetes deployments are definitely more intricate. For dev and staging environments, ECS with Fargate Spot is a great cost-saving option, offering up to 70% savings while providing around 90% uptime, which is perfectly fine for startups.

To view or add a comment, sign in

More articles by Shrey Batra

Explore topics