ALB and ECS Service
data:image/s3,"s3://crabby-images/c18c9/c18c92a6ae3394d94232b96b85d155521d2abd31" alt="Scale the adoption platform monolith with an ALB and an ECS Service"
The Run Task method used in the previous section is great for testing, but if needed to run the platform apply it as a long-running process. You need to use Elastic Load Balancing Application Load Balancer (ALB) to deliver requests to your running containers. In addition to simple load balancing, it also creates capabilities such as path-based routing to different services.
ECS helps maintain the number of desired tasks (the number of containers running for a long time) and integrates ALB (handles the registration/deregistering of containers into the ALB)
The original ECS and ALB service was created by CloudFormation. In this lab, you will update those resources to host the encapsulated monolith service. Then you will create a new service from scratch after breaking the monolith.
- Access to CloudFormation
- Select STACK_NAME
- Select Stack details
- Select Outputs
- Select LoadBalancerDNS
data:image/s3,"s3://crabby-images/9d2e7/9d2e74e43ae1e85b203f9f0d63f6d5a809369b19" alt="Deploy the container using AWS Fargate"
- Use your browser to access LoadBalancerDNS
data:image/s3,"s3://crabby-images/40197/401973006cd42a78d01ef7a791b874d95a831ff9" alt="Deploy the container using AWS Fargate"
- Go to ECS
- Select Clusters
- Select Cluster-STACK_NAME
data:image/s3,"s3://crabby-images/0a9ea/0a9eab66b35d2817682723dd858fda5825700416" alt="Deploy the container using AWS Fargate"
- In the Cluster-STACK_NAME interface, we proceed to update service
- In the Services section, choose the lab service
- Click Update
data:image/s3,"s3://crabby-images/f7da0/f7da08b3d666a580b54a663a08fead1f27d0d262" alt="Deploy the container using AWS Fargate"
- In the service update interface
- Select the latest Revision
- Click Update
data:image/s3,"s3://crabby-images/fb93c/fb93ccfdc8c4cea1571241db102017264a2493c5" alt="Deploy the container using AWS Fargate"
- Service update is successful.
data:image/s3,"s3://crabby-images/e65d5/e65d5a9d72160528c796bcd4db858b60a4bb86aa" alt="Deploy the container using AWS Fargate"
- In the Cluster-STACK_NAME interface
- Select Task
- Check Monolith-Definition-STACK_NAME has been updated to Revision 22 (or any latest revision)
data:image/s3,"s3://crabby-images/00db8/00db8841792d4339c0774502dbb0b5c97d7dc673" alt="Deploy the container using AWS Fargate"
- Access to CloudFormation
- Select STACK_NAME
- Select Stack details
- Select Outputs
- Select S3WebsiteURL
data:image/s3,"s3://crabby-images/9a0be/9a0befc008bfca8777a19fea95f6cae69558e658" alt="Deploy the container using AWS Fargate"
- Use a browser to access S3WebsiteURL
data:image/s3,"s3://crabby-images/e0b26/e0b2652036bcdb2366212d9c6568799a6d24673a" alt="Deploy the container using AWS Fargate"
- Perform user interface experience operations
data:image/s3,"s3://crabby-images/576f4/576f41581ebf696f20bc11f94ddf30ac4f1ce62f" alt="Deploy the container using AWS Fargate"
- Access to ECS
- Select Cluster
- Select Cluster-STACK_NAME
- Select Tasks
- Select Monolith-Definition-STACK_NAME revision 2
data:image/s3,"s3://crabby-images/b5aad/b5aad05cc38004f1d65c9eedc6d665f9f1a169d3" alt="Deploy the container using AWS Fargate"
- Select Logs
data:image/s3,"s3://crabby-images/9b179/9b1792e5acb601cbe34f514c81571bca08f001e9" alt="Deploy the container using AWS Fargate"
- Check the logs to make sure the monolith can read and write DynamoDB and can handle the like.
data:image/s3,"s3://crabby-images/98995/98995bdc89eb878eedf33e5d2cd2f037c08e93d6" alt="Deploy the container using AWS Fargate"
- Check CloudWatch logs from ECS to make sure Like processed
data:image/s3,"s3://crabby-images/38a84/38a84ac2d637763287812a271a0f9215ea42ef6f" alt="Deploy the container using AWS Fargate"
- Access CloudWatch
- Select Log groups
- Observe event log
data:image/s3,"s3://crabby-images/03c3a/03c3aeab30ac86186c2e6ac48e6a4bdf1477ed8e" alt="Deploy the container using AWS Fargate"
- To distinguish between service and task. We can do the following steps:
- Select the service with the latest Revision
- Click Update
data:image/s3,"s3://crabby-images/c98d9/c98d9fde663eff90fa1d6059e2c581b4d3abfed8" alt="Deploy the container using AWS Fargate"
- Increase Desired task to 3 and update.
data:image/s3,"s3://crabby-images/14180/1418083b7d74ec98740bf54844cc9ebe988015b1" alt="Deploy the container using AWS Fargate"
- After a successful update.
- Select Task to see 3 running tasks.
- From there, we see ECS services is a concept in which ECS allows running and maintaining a specific number of containers of task definitions in an ECS cluster. A service consists of many tasks and is maintained.
data:image/s3,"s3://crabby-images/2728a/2728a1c6a527fecc3b4e9370e538ddd8e50b9644" alt="Deploy the container using AWS Fargate"