Table of Contents
Architecture Diagram
data:image/s3,"s3://crabby-images/a6026/a60268f261307945635a9bf1f57b428f79412004" alt=""
Step-By-Step Guide
Step 1. Create a Security Group for the load balancer and EC2 Instance
a. Sign in to AWS Console and search for EC2
data:image/s3,"s3://crabby-images/aae47/aae47015a05fd20f90d1fded9a7040dffcd02931" alt=""
b. Navigate to Network & Security > Security Groups
data:image/s3,"s3://crabby-images/6955b/6955b3fa8536351cb8c4333596143feb404ed1cd" alt=""
c. Create a security group using the following configurations
- Name: ALB-EC2-SG
- Description: Security group for the load balancers and EC2 Instance
- Select default VPC
data:image/s3,"s3://crabby-images/9719b/9719b09851cacfbdcde72b75e13888ab1481751d" alt=""
d. Add an Inbound Rule to allow HTTP traffic on port 80 from Anywhere
data:image/s3,"s3://crabby-images/9720c/9720c9acc9f3f1c8bb309ce90068cb3f0de70ad8" alt=""
data:image/s3,"s3://crabby-images/a580f/a580ff8f9232dfc310ae8626d48abd779645e486" alt=""
e. Click on the Create Security Group Button
data:image/s3,"s3://crabby-images/cbfb5/cbfb51eec596f0173a775b97e10fd880f8b5eee2" alt=""
Step 2. Launch 2 EC2 Instances
a. In the left-hand side panel, navigate to Instances > Instances and click on the Launch Instance Button
data:image/s3,"s3://crabby-images/70605/706050548fe5cc3e3b968ce02bb6aa9d36172e73" alt=""
b. Use the following configs
- Name: My-Instance
- Summary > Number of instances: 2
data:image/s3,"s3://crabby-images/3d75a/3d75ad72759ab7611f78f3ca84cf0ffcaf2f4675" alt=""
data:image/s3,"s3://crabby-images/ce1e3/ce1e32412dc6b21d3ddaaa672ac7e793a3f78fb4" alt=""
data:image/s3,"s3://crabby-images/a86d5/a86d5fa372830b5cecd3ae0a0cd23f0e324fdff1" alt=""
data:image/s3,"s3://crabby-images/b1044/b104460a598fa6ec67bdd1fda9b0b9a467160ab7" alt=""
c. Do not create a Key pair; it is not needed. Proceed without key pair
data:image/s3,"s3://crabby-images/2b331/2b331343ac26e8b36fc9a2172f87aa576bb5de0f" alt=""
data:image/s3,"s3://crabby-images/9b354/9b354f7b446652e1abfab470d789f16cc43c3e2a" alt=""
d. In the Network Settings, select the following:
- Default VPC
- The subnet in the Availability Zone: us-east-1a
- Auto-assign public IP: enable
- Select existing security group and
- select ALB-EC2-SG from the dropdown list
data:image/s3,"s3://crabby-images/4c064/4c0647865610d1a3d0b51481ece856e91b27b31f" alt=""
data:image/s3,"s3://crabby-images/22d75/22d7587799f31bd0fa29c7c98735ab164daffd92" alt=""
e. In User data, under the Advanced Details section add the following statements
1 2 3 4 5 6 7 |
#!/bin/bash sudo su yum update -y yum install httpd -y echo "Hello World from $(hostname -f)" > /var/www/html/index.html systemctl start httpd systemctl enable httpd |
data:image/s3,"s3://crabby-images/8c405/8c40537a8f2b418df1b879febc511e84042a14a1" alt=""
f. Click on the Launch Instance Button
data:image/s3,"s3://crabby-images/749e1/749e1a48d3d28a3dc7a9fc8b979ae89836f902c1" alt=""
data:image/s3,"s3://crabby-images/8e561/8e5618a93ebf6daa07e05a540ab1ec87df389b6a" alt=""
Step 3. Create target group and application load balancer
a. Navigate to EC2 > Load Balancing > Target Groups and click on the Create target group button
data:image/s3,"s3://crabby-images/19867/198679e3c5d90810166d720f7befee4bb0e95c60" alt=""
data:image/s3,"s3://crabby-images/94213/9421315cd5635442d3d3266f1bf4ed23ef02f71d" alt=""
b. Create a target group using the following config
- Target Type: Instances
- Name: EC2-TG
- Protocol: HTTP
- Port: 80
data:image/s3,"s3://crabby-images/8e34b/8e34be5f15d956d7ae0e3d8291409e3122f7828a" alt=""
c. Select Default VPC and Protocol Version: HTTP1
data:image/s3,"s3://crabby-images/89a08/89a080b987301199f48f8ac90972a11e79d80c8a" alt=""
data:image/s3,"s3://crabby-images/9e374/9e3742ca2da07e18634bfcfd8b30514d79865812" alt=""
d. Click on the Next button
e. In the Regster Targets section, add both the instances and click on the “Include pending as below” button
data:image/s3,"s3://crabby-images/b7170/b7170c74051bd62cac734bbb039671f29eef926a" alt=""
f. Click on the “Create target group” button
data:image/s3,"s3://crabby-images/a58a2/a58a2929c23d782d1abc369d05be14549f2b5b39" alt=""
data:image/s3,"s3://crabby-images/91548/915488398a8b8b977a1fe91142b45417c93f05d0" alt=""
g. Now create load balancers by navigating to Load Balancing > Load Balancers and clicking on the “Create load balancer” button
data:image/s3,"s3://crabby-images/25daa/25daa08f39ac4eaf7ebd8e827bd3c5efe246bf0e" alt=""
data:image/s3,"s3://crabby-images/cd29b/cd29bd1a29b1b109911ccda9b1a86aadd749d1c3" alt=""
h. Select Load Balancer Type: Under the Application Load Balancer, click on Create Button.
data:image/s3,"s3://crabby-images/5512d/5512dce680f54e7ee794cea280a35f42a1514248" alt=""
i. for the Basic configuration, use the following details
- Name: Enter Web-server-LB
- Scheme: Select Internet-facing
- IP address type: Choose IPv4
data:image/s3,"s3://crabby-images/bc604/bc604a8823c59720917b352ec38282165df0c837" alt=""
j. under the Network mapping section, select Default VPC and AZ us-east-1a and us-east-1b
data:image/s3,"s3://crabby-images/6003b/6003be70a94ba9685e1a66e668568fd5b6ef66d0" alt=""
k. Select ALB-EC2-SG as the security group and default action forward to EC2-TG
data:image/s3,"s3://crabby-images/03fae/03fae8834e1c3d39b167514d04b0a18bebc86b56" alt=""
data:image/s3,"s3://crabby-images/f0fcc/f0fcc61f708d75cfbce5a81a6113b3aa54b59291" alt=""
l. Review the Summary section and click on the “Create load balancer” button
data:image/s3,"s3://crabby-images/5d033/5d0331f39c29af8e649d5ee4a2f818eb5612a095" alt=""
data:image/s3,"s3://crabby-images/bfe3d/bfe3dc01158636b591ebca7028914099a4daa78d" alt=""
m. Wait for the load balancer to become active.
data:image/s3,"s3://crabby-images/48278/48278cee1946719e609ef7d32390e30522d5a777" alt=""
Step 4. Enable stickiness by modifying the Target Group attribute
a. Navigate to Load Balancing > Target Groups
data:image/s3,"s3://crabby-images/deab4/deab43f314ccd87e03aa3d38a80c40aa75155fcb" alt=""
data:image/s3,"s3://crabby-images/7a042/7a0427f5825917bb1b7d80c2be4d5243343fb194" alt=""
b. Select Attributes tab and click on the Edit button.
data:image/s3,"s3://crabby-images/33e85/33e853fb32feff598b95466182d75cf83b1b81c5" alt=""
c. In the Target selection configuration, toggle “Stickiness” button to on and set Stickiness duration to 2 minutes and save.
data:image/s3,"s3://crabby-images/426e0/426e06b759a3a0c2978d547d284d10b1dc967d3a" alt=""
Step 5. Testing the stickiness
a. Navigate to Load Balancing > Load Balancers
data:image/s3,"s3://crabby-images/d9583/d9583e7d83cc85e0fb5ffc77f250ddd103addf98" alt=""
b. Select the Load balancer and copy the DNS name of your load balancer, and paste it into the browser.
data:image/s3,"s3://crabby-images/17c7a/17c7a4ea7f57bb89f0f33b007a5dc895ba4d6940" alt=""
data:image/s3,"s3://crabby-images/9284f/9284ff7fbf0a367f5fea9ac634b3db672c81d0ae" alt=""
c. After 2 minutes, it should be redirected to a new page.
data:image/s3,"s3://crabby-images/aa8dc/aa8dc713b8c8924e07d620257fd95a0a2382bffb" alt=""