We have already created a Docker image for the server using Nginx. We will create an AWS ECS Fargate cluster in AWS and host the container there.
Create an ECR repository for the image
Select the Elastic Container Registry
data:image/s3,"s3://crabby-images/ae7f2/ae7f2743e39a1796f7686619e261c334243cace4" alt=""
Create a new repository
data:image/s3,"s3://crabby-images/8d5c2/8d5c2e9b55d2bfc0f26769e3b3ca66d82b74f1c5" alt=""
Enter a name, enable Tag immutability and Scan on push
data:image/s3,"s3://crabby-images/8d148/8d1481afd22d960cc98040be1c577514519562e3" alt=""
Select the repository you just created and click the View push commands button
data:image/s3,"s3://crabby-images/aa45c/aa45c025bdf9ad46a5e74fc2f1f619816075788e" alt=""
Follow the instructions on the next page to authenticate in the registry, build your Docker image and push it to the registry.
# Authenticate in ECR
aws ecr get-login-password --region us-east-1 | docker login --username AWS --password-stdin MY_ACCOUNT_NUMBER.dkr.ecr.us-east-1.amazonaws.com/MY_ECR_REPOSITORY_NAME
# Build the image
docker build -t MY_DOCKER_IMAGE_NAME .
# Tag the image
docker tag robbers-rummy-server:latest MY_ACCOUNT_NUMBER.dkr.ecr.us-east-1.amazonaws.com/MY_DOCKER_IMAGE_NAME:$1
# Push the image
docker push MY_ACCOUNT_NUMBER.dkr.ecr.us-east-1.amazonaws.com/MY_DOCKER_IMAGE_NAME:$1
If this is the first ECS cluster of the account the Getting Started button launches the ECS Wizard. See Using the ECS wizard to create the cluster, service, and task definition below.
Create the ECS cluster
Create a new ECS cluster in the new VPC
data:image/s3,"s3://crabby-images/7aa46/7aa46bb41cb552c5acb915ec43f7e1eb7a97c0c2" alt=""
- Select the Fargate cluster template
data:image/s3,"s3://crabby-images/2ae22/2ae22f7ef5afd48406569d3ba1b6ceba761058a0" alt=""
For production clusters, add a third subnet for redundancy. This way of one of the availability zones develop issues, the cluster can use the third subnet for high availability.
data:image/s3,"s3://crabby-images/556ac/556ac6c389fbed8e8b60bce15a1051aa547fae18" alt=""
For production clusters also enable Container Insights for advanced logging
data:image/s3,"s3://crabby-images/162f6/162f6f4def5d892f7ecdb1260b11077046e1ea80" alt=""
Create a security group
Create a security group in the new VPC with an ingress rule for the necessary port and protocol. Open port 3000-3001 for production and test for blue-green deployment.
data:image/s3,"s3://crabby-images/9e8b5/9e8b542fcb27d2c74c5e5251f6542fb673fe3cb6" alt=""
Create an Application Load Balancer
Create a new Application Load Balancer in the new VPC, but do not add any listeners and target groups. Those will be created by the ECS Fargate Service creation.
data:image/s3,"s3://crabby-images/22fbb/22fbb7f0c8e7ba338fe492a117ad8fc6c554ab8f" alt=""
This is fine, we don;t need listeners now.
data:image/s3,"s3://crabby-images/53518/5351869045ef2838a090c31243dfd6ccea539c20" alt=""
Add the security group to the Load Balancer.
data:image/s3,"s3://crabby-images/0fc6e/0fc6e767bb1e974a9f77ce46d2dc448b036706e6" alt=""
We have to create a temporary target group, we will delete it later.
data:image/s3,"s3://crabby-images/1233e/1233e130a7328808d9dcf9e489757bf236e0f8ec" alt=""
Do not register any targets, the ECS service creation process will create the target group and register the target.
data:image/s3,"s3://crabby-images/15b28/15b28c79110566ed32e79a4932ea1440ec982c2b" alt=""
Create an ECS Task Definition
We will use the task definition when we will create the Service
data:image/s3,"s3://crabby-images/7ad60/7ad60871f03b195d21a0e875f4683f33603d4a42" alt=""
In this example, we will create a Fargate Task Definition
data:image/s3,"s3://crabby-images/7c43b/7c43b75988fc02f6659e3af367d9b2b3e6707296" alt=""
data:image/s3,"s3://crabby-images/9d847/9d847241ea72d000a9582240b46abbe28aff2184" alt=""
Select the memory, CPU sizes and click the Add container button
data:image/s3,"s3://crabby-images/76edd/76edd61785baec68d7e1b330d0942641591d0415" alt=""
Configure the container
data:image/s3,"s3://crabby-images/57d01/57d01601bb8ab557bcb1021bcf5d059ae7f8c148" alt=""
Set the environment variables
data:image/s3,"s3://crabby-images/3a9df/3a9dfc492ce0664ec4d87a8336871fabb1f0093a" alt=""
Create a service role for CodeDeploy
Create a service role for CodeDeploy in the IAM console.
data:image/s3,"s3://crabby-images/eaa26/eaa26f8dc6d82cd8b3f88cc640ee97572fe49b68" alt=""
data:image/s3,"s3://crabby-images/623ce/623cedc860b277c273a9d4ea995e0870943a8033" alt=""
data:image/s3,"s3://crabby-images/8bf4b/8bf4b42f21a75897831e845b892fcb3995d5bf3f" alt=""
Create the service
Create a new Farate service in the new cluster. Click the name of the cluster.
data:image/s3,"s3://crabby-images/03c1f/03c1f462cc3a13aa8ecf3da98c31b82d6c933199" alt=""
On the Services tab click the Create button
data:image/s3,"s3://crabby-images/535c3/535c333fdb0c0828586dc9498f5d3c0482184bdc" alt=""
data:image/s3,"s3://crabby-images/9c8c6/9c8c66c55ef002f6bb26aed8fab1417ec936aae2" alt=""
data:image/s3,"s3://crabby-images/39f24/39f2439b684db8f321a1090e6ce15947ec549692" alt=""
- Select the new VPC, the subnets, and click the Edit button to select the new security group
data:image/s3,"s3://crabby-images/ce5dd/ce5dd13d4dcaa583f283f2bb19c1f2cb3a68a7c7" alt=""
- Select the new security group
data:image/s3,"s3://crabby-images/ce704/ce704442d7b97010ef017e512e265b4d47bab6e0" alt=""
Click the Add to load balancer button to add the container to the load balancer. Select the Application Load Balancer type
data:image/s3,"s3://crabby-images/be2e0/be2e0323194d8aa529dd5d3ecd2ee201efd13756" alt=""
- Select HTTP for the listeners, for some reason at the time of writing we cannot select the SSL certificate on this page
data:image/s3,"s3://crabby-images/bfaf7/bfaf73958c1684aba0b3257284d1a1cb6aca6df2" alt=""
data:image/s3,"s3://crabby-images/521e7/521e7d2197f8d1c2005fdf278fc796687842a27c" alt=""
Create a new listener for testing during the blue-green deployment
data:image/s3,"s3://crabby-images/58840/588400bcef696fc76de8a01cb6fca71659ba889d" alt=""
Edit the name of the target groups if needed
data:image/s3,"s3://crabby-images/c65f2/c65f2043eca5baec96392ac8237f85fa32a06ba4" alt=""
data:image/s3,"s3://crabby-images/ef896/ef896480b6313e0168fd552087e044efff58750f" alt=""
For now, we don’t set up autoscaling
data:image/s3,"s3://crabby-images/65d16/65d16da9d0f4d1df081a9d9f0663ab6ed200e8d5" alt=""
Enable HTTPS in the load balancer listeners
data:image/s3,"s3://crabby-images/284c3/284c31a9577cc7c2558a47beda10d5b4528a7c66" alt=""
Select HTTPS, port 3000, and the certificate
data:image/s3,"s3://crabby-images/11a1b/11a1b21c3772f6e030f6ba841d6deba8060ca729" alt=""
Add 404 to the health check success codes
Socker.IO returns 404 when we call the root path, so add 404 to the target group health check success codes
- Select the target group name
data:image/s3,"s3://crabby-images/2df97/2df975699a44dc69c4d0bd092450fa0b4739641d" alt=""
- In the Health Check settings panel click the Edit button
data:image/s3,"s3://crabby-images/94360/94360a6dda2e64835846cc6ffaa9418213c44c87" alt=""
- Click the Advanced Settings arrow
data:image/s3,"s3://crabby-images/cfada/cfada8b7c9af44e325d474b8d49cae7b74ce2aca" alt=""
Add 404 to the success codes
data:image/s3,"s3://crabby-images/902a5/902a5ed07806a01a529a3617fafa95e737b59cdf" alt=""
If this is the first service of the cluster, the wizard will guide you through the Service creation process.
In the AWS console select Elastic Container Service
data:image/s3,"s3://crabby-images/fc4da/fc4da09e16be8bf01c3532e190ab9a4543fd91cf" alt=""
Click the Get started button
data:image/s3,"s3://crabby-images/50f50/50f506fe88c0b1d88d929b9cbd388794b6704dc3" alt=""
Click the Configure button in the custom configuration
data:image/s3,"s3://crabby-images/003cb/003cb72564842b6c619b471ceba934e360a0845a" alt=""
Enter the
- Container name
- Image
- Memory limits (soft limit) = 512
- Container port = 3000
data:image/s3,"s3://crabby-images/f306d/f306d0876ca6d789d73af74f17acaaf635168e49" alt=""
Click the Advanced container configuration arrow
data:image/s3,"s3://crabby-images/f015c/f015c314bf31e96d6a21c0bede5de350be928b04" alt=""
Add the environment variable NODE_ENV
=production
data:image/s3,"s3://crabby-images/932b2/932b2a1d8e041daddd5e3fdcf635ec7b3b642553" alt=""
Under Storage and Logging enable Auto-configure CloudWatch Logs
data:image/s3,"s3://crabby-images/aa0ef/aa0efa4d7c99ac9d1e3428b12aa0447329d5bc63" alt=""
Click the Save button
Keep the default task definition and click Next
data:image/s3,"s3://crabby-images/f733b/f733b0bb6ca42584c555640c43b426eb44687f4f" alt=""
Edit the Service definition
data:image/s3,"s3://crabby-images/c850e/c850e56847aa36abc77c0eaa1b4dcc1cad497dc0" alt=""
data:image/s3,"s3://crabby-images/c2891/c2891151cee6cd38fe0c6ea70b3c01c4ebcd0a9d" alt=""
data:image/s3,"s3://crabby-images/ff631/ff63146e87635d76ec4d52280ee3590a245715a0" alt=""
data:image/s3,"s3://crabby-images/b3941/b394162506efaeeaf528eda648386dec08aedb41" alt=""
Create the load balancer
data:image/s3,"s3://crabby-images/ed4eb/ed4eb7220963bba43775a7ec6ce09bf6d35b3da0" alt=""
data:image/s3,"s3://crabby-images/e095c/e095c79cc2b9716bc1d7f0e1396205893ff7e8ba" alt=""
Add 404 to the health check success codes
data:image/s3,"s3://crabby-images/f246f/f246ff206f2e9d1e8104237d182db426e9c39876" alt=""
When you return from the Load Balancer creation refresh the Load Balancer list
data:image/s3,"s3://crabby-images/e1b02/e1b023bf65400642907bccbe3dc046829bea2a52" alt=""
data:image/s3,"s3://crabby-images/9a269/9a269ad6d663d0376eab96c4014c127733cef225" alt=""
Keep the Cluster definition and click Next
data:image/s3,"s3://crabby-images/249a4/249a4e81575b3e5630901eb05e2dac4e2b6f823d" alt=""
Click the Create button to create the cluster
When enabled, click the View service button
data:image/s3,"s3://crabby-images/3ffe0/3ffe00f4eea52057990caf2d2c49dafef860a2d0" alt=""
data:image/s3,"s3://crabby-images/93257/93257bbf812c1aeb92fb863dc3494fe3c6d3e620" alt=""
Create a CI/CD pipeline and connect it to an ECR repository
data:image/s3,"s3://crabby-images/e725e/e725e501e143d8f28e622fbcabe4154c28534a15" alt=""
data:image/s3,"s3://crabby-images/9e45d/9e45d309fac859343c2539dddc563911c1ec9e67" alt=""
data:image/s3,"s3://crabby-images/7a0eb/7a0eb051e3f1cd795e5216a17cf84003e03e699f" alt=""
data:image/s3,"s3://crabby-images/ea231/ea23121e47e395f98dc5b4404691adc08449cade" alt=""
data:image/s3,"s3://crabby-images/a02cc/a02cc407fa85bee85eefca47acdaf7960665c8ca" alt=""
Enable HTTPS in the listener
- Create an SSL certificate in the AWS Certificate Manager
- Update the load balancer listener to use HTTPS on port 3000
data:image/s3,"s3://crabby-images/0aef6/0aef6154787cdb955d4ed930df84edb3222301d0" alt=""