Amazon Elastic Beanstalk vs EC2 instance with docker containers
Solution 1
AWS has integrated Elastic Beanstalk (EB) with the EC2 Container Service (ECS) to support multi-container Docker environments. An EB environment composed of multiple instances in an autoscaling group can run multiple containers per instance, managed through the ECS agent and its API. Use .ebextensions
to map multiple ELB listeners to the containers running on EC2 instances.
See this tutorial for running an Nginx + PHP-FPM in separate containers.
Thanks @Synturas for tipping me off to this update.
Solution 2
Yes your assumptions are correct. The difference is that for doing it on EC2 you will have to manage and monitor your containers all by yourself. So I guess for production environments you'll have to have your own team for that, or else go with BeanStalk.
Also better follow this Docker on Amazon documentation.
Edit
Thanks for the comment @sajithp I have updated the link
Nick
Well-rounded developer proficient in web (React) and mobile (React Native). Currently exploring the exciting world of Kubernetes.
Updated on June 14, 2022Comments
-
Nick almost 2 years
If I understand correctly, Elastic Beanstalk creates an EC2 instance for each application you deploy. However, an application typically doesn't run at 100% CPU, yet amazon charges you per instance used. So if I deployed 5 apps with Dockerfiles, AWS would charge the usage of 5 EC2 instances per month.
With this in mind, can't I just simply launch an EC2, install docker and run my containers in there? Wouldn't that be much more cost-effective?