Skip to content

olivierots/Deploy-a-NodeJS-WebApp-Using-Terraform-Docker-Fargate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 

Repository files navigation

Terraform-Docker-Fargate-aws-Nodejs-WebApp Project

== Project 1 description ==

This is a nodejs web app thats been built using Docker
When an end user browse to the website, the web server takes that request
and calls the requested api as described in the server.js file
e.g /api/users endpoint. which will then load & display all the information 
from the db.json file on a web browser. 

## architecture of the network ##
1. I have an application load balancer pointing to an ECS cluster which has 4 containers running
2. The containers will doanload the image from the ECR which an aws repo where the container's images are stored in
3. ECS pulls the images and run as a dokcer containers
4. All logs will be pushed from the ecs containers to cloudwatch 
5. Auto scaling policies attached to the ECR are also in place for capacity management
6. The docker image will be stored in docker repo called ecs-service in aws which is ideal for private images

Technical Implementation

==== Docker part
* downloaded a node base image & built the custom image on top of it
* docker exposes port 3000 - see dockerfile for container configs

==== Terraform part
* created an ECR repo 
* tagged my docker image to the uri for the ECR repo 
* pushed the image to the ECR for ECS to run it as docker container
* the ECS cluster will be running the image which is located in the ECR repo
* built an ECS cluster (fargate) with 3 docker instances for my app
* The ALB will be placed in front of the service to route, split users requests
  accross the 4 configured containers (ECS cluster).
* auto scaling has been configured to run at least 4 EC2 instances & when the cpu threshold
  goes above 80% the instances will scale up. min at a time =3 and max will be 10.
* scale down , when the cpu util. goes below 20% the instances will scale down the instances
  (cost effective & performance efficient)
* I've also configured the ECS to send logs to cloudwatch dashboard, cloudwatch triggers will
  help us know the auto scaling policies 
* The docker image is stored in the docker repo called ecs-service in aws (private image repo)
  
==== what happens in the case of a software upgrade ?
* whenever there is a new image, all i have to do, is to push that image to the ecr with a new
  version.

Other important technical definitions to better understand this project

* ECR: elastic container registry 
ECR gives you an environment where you can configure your docker container to execute it in aws 
it handles everything from installing the docker deamon for the container to run , task def etc. 
ECR is integrated with ECS & transfers your container images over HTTPS and automatically encrypts
your images at rest.You can easily push your container images to Amazon ECR using the Docker CLI
from your development machine, and Amazon ECS can pull them directly for production deployments.

* ECS: elastic container service 
Highly scalable, high performance container management service that supports Docker containers
and allows you to easily run applications on a managed cluster of Amazon EC2 instances
ECS eliminates the need for you to install, operate, and scale your own cluster management 
infrastructure.Amazon ECS maintains application availability and allows you to scale your 
containers up or down to meet your application's capacity requirements.

* Docker: software deployment platform for deploying applications, applications are packaged in
  containers, it can run on any OS & containers can easily scale. 

ECS is implemented in aws in two ways: EC2 & Fargate

1. EC2:
launch a docker container on aws with ecs
has support for ALB & ASG
user should provision ec2 where container will be run by ecs 

2. Fargate:
amazon proviison your ec2 (serverless)
no need to worry about ec2 instances
so you no longer have to provision, configure and scale clusters of VMs to run containers 

== Project 2 (simple terraform challenge) ==

1. created an ec2
2. created a sec. group with the below rules using variables
   2a. ingress rules:80,443,25,3306,3389,8080
   2b. ingress rules:443,8443
3. attached a public IP
4. created an elastic IP
5. terraform will output the below
   5a. output the public IP
   5b. check the expected ports to be open
   5c. confirm open port

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published