This is a diagram that I have used for this lab.
data:image/s3,"s3://crabby-images/4f4e6/4f4e60cc40916ff3e1821cb839f0207ee6e0d695" alt=""
There are several main steps that I have used in the lab.
- Create four private subnets on four AZs.
- Create a WordPress instance on the first AZ.
- Create a new MySQL instance on Multi-AZs deployment.
- Create an AMI image for the WordPress instance.
- Create a Launch configuration.
- Set up an Auto Scaling Group with your launch configuration.
- Request ALB certificate via AWS Certificate Manager.
- Configure HTTPS listener on ALB.
- Configure the HTTP listener and redirect the HTTP traffic to HTTPS.
- Create a CNAME record on your DNS zone for the Amazon domain name.
- Test an Application Load Balancer for WordPress on multiple AZs with MySQL instance on Multi-AZ deployments.
- Configure Amazon CloudFront.
- Test an Application Load Balancer for WordPress on your cloudfront.net domain.
Create a new VPC.
data:image/s3,"s3://crabby-images/1016a/1016aa521cbf60647041d010892815517a9db313" alt=""
Create 4 private subnets on 4 Availability zones.
data:image/s3,"s3://crabby-images/f1ed1/f1ed14b2322a3fcec9147da38a66efe197d07a4c" alt=""
data:image/s3,"s3://crabby-images/b9049/b9049087461bcc9ce64c6a48ada1ad3df985792f" alt=""
Create and attach a new Internet Gateway to your VPC.
data:image/s3,"s3://crabby-images/1bf1d/1bf1dd495669fd9ef24625ef58501f39d80cf41c" alt=""
Create a static route 0.0.0.0/0 on your VPC.
data:image/s3,"s3://crabby-images/f653b/f653b0b2aec886df4db845ccb498bc59f40ea0f2" alt=""
Create a Linux instance.
data:image/s3,"s3://crabby-images/f2087/f2087fe8d94d4979c209229bd72e709d1d55c1f7" alt=""
Copy it into the User data setting.
#!/bin/bash
yum update -y
# Install Apache web service
yum install httpd -y
# Download WordPress
wget https://wordpress.org/latest.tar.gz
tar -zxf latest.tar.gz
# Install php7.4
amazon-linux-extras install php7.4 -y
Create a WordPress-SG.
data:image/s3,"s3://crabby-images/26a3e/26a3e559f0da5aed96ea7ae8d3f35eab7a3e469a" alt=""
Create a new Security Group is WordPress-ALB-AutoScaling for ALB AutoScaling.
data:image/s3,"s3://crabby-images/16bd5/16bd5fbfc8b42b3248134141bd6c0cf9343c0462" alt=""
data:image/s3,"s3://crabby-images/a1b85/a1b8566368b596ff218c79684f768a5f484c770b" alt=""
SSH to the Linux instance, and check httpd, php is installed on the machine.
rpm -qa | grep httpd
rpm -qa | grep php
sudo yum install php -y
sudo systemctl start httpd
sudo systemctl enable httpd
netstat -antp
Copy all files on WordPress directory to /var/www/html.
cd wordpress
sudo cp -r * /var/www/html
cd /var/www/html
Create an ip.php file on /var/www/html directory.
#sudo nano ip.php
<?php
echo "Local IP address: "; echo $_SERVER['SERVER_ADDR'];
echo "<br>";
echo "Public IP address: "; echo $_SERVER['SERVER_NAME']
?>
Install mod_ssl on the Linux instance.
sudo yum install mod_ssl
Create a TLS certificate for the Linux instance.
sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/pki/tls/private/localhost.key -out /etc/pki/tls/certs/localhost.crt
data:image/s3,"s3://crabby-images/1a136/1a1364faf8b47c645fdad26ad8734d5b401f505a" alt=""
Restart apache web service.
sudo systemctl stop httpd
sudo systemctl start httpd
Check https is running on the Linux instance.
data:image/s3,"s3://crabby-images/723be/723beb97b5b9db10c66b8268c50373463225f4bf" alt=""
Go to RDS, and create a new database subnet.
data:image/s3,"s3://crabby-images/0de00/0de00c5c1ad844cc2ccdd40da0aee23a5939e3f6" alt=""
data:image/s3,"s3://crabby-images/64bc3/64bc37e9f0a4838dd37668670169d991898dd03d" alt=""
Create a new database instance on AWS.
data:image/s3,"s3://crabby-images/da284/da284838dfe1362523bcabe367136dbbee9b204c" alt=""
data:image/s3,"s3://crabby-images/5d212/5d2125ec1e3316840bdb995375e514a6626c6483" alt=""
data:image/s3,"s3://crabby-images/b9218/b921846bd221f8890b3c7017794eb10dc10fd380" alt=""
data:image/s3,"s3://crabby-images/e707f/e707ffad0d42e7290b4ce06354ddec619f30e94d" alt=""
data:image/s3,"s3://crabby-images/9ffe1/9ffe123d2491bcac8deef7eedf6eee4e67f4d856" alt=""
Create a database.
data:image/s3,"s3://crabby-images/9856a/9856aca67b3b0e268e9bc540e8ce2e6f9be1e029" alt=""
data:image/s3,"s3://crabby-images/b0964/b0964032ff33fe2e3927a7c5bc58cc16c1e29c9c" alt=""
data:image/s3,"s3://crabby-images/6c1d7/6c1d74781178dd3f6b07752d48e0bc91a46fa9cf" alt=""
Open https://18.209.221.54 on your web browser to set up WordPress.
data:image/s3,"s3://crabby-images/78dbe/78dbee7bfcd969fb686a604f5a0c40aeb6b45742" alt=""
data:image/s3,"s3://crabby-images/62329/62329559611afec683ac2a38beccbc7a12b04afc" alt=""
Create a new wp-config.php under /var/www/html directory, and paste the information on the screen to this file. Click “Run the installation”
data:image/s3,"s3://crabby-images/275e3/275e34c6b5361d8efbaa3f5204adfda3d4ab45c9" alt=""
data:image/s3,"s3://crabby-images/a75b2/a75b242830bd5ae505cc3052b9f6facbda5a2f3c" alt=""
data:image/s3,"s3://crabby-images/31ed9/31ed99d7649bd0441fa9b2ea23d1b375987399ba" alt=""
Check the connection from WP to RDS instance via the port 3306.
data:image/s3,"s3://crabby-images/c09f0/c09f08283eb71ef32dc611093ee38c241b12902e" alt=""
Create an image for the WP instance.
data:image/s3,"s3://crabby-images/2f5bf/2f5bf117b43d1f738b4e6c138f84ccd3c90660d9" alt=""
data:image/s3,"s3://crabby-images/1e801/1e8014bd7c7e7a01e1d6469bfcaa92998866a2cd" alt=""
Go to launch configuration and create a launch configuration.
data:image/s3,"s3://crabby-images/0b45b/0b45b0a754648b40a9691185c116d9877252ba2f" alt=""
On Advanced configuration – advanced details – Select “Assign a pubic IP address to any instances”
data:image/s3,"s3://crabby-images/b389d/b389d4a4a0f00004c5777a6491b6a27ad709f6ae" alt=""
Select an existing security group. Click create a launch configuration.
data:image/s3,"s3://crabby-images/bfee3/bfee34cb5879841d32473fe38f330a7071532737" alt=""
data:image/s3,"s3://crabby-images/584ff/584ff76e402d16b8a32fb5e048f89775695b13cd" alt=""
Go to Auto Scaling Group and create a new one.
data:image/s3,"s3://crabby-images/fb509/fb509010ac10805eb9ac9abc9c3a9f8ca8edef52" alt=""
data:image/s3,"s3://crabby-images/cb2e4/cb2e41cc749a729ba7cc053c1099bab60cd2e006" alt=""
Enable “Internet-facing” on load balancing scheme.
data:image/s3,"s3://crabby-images/2e664/2e6645c15d48b2ef395148924ad9901d6b910a32" alt=""
data:image/s3,"s3://crabby-images/a82f3/a82f3e096955d99f470bd4f3f11e91df33b87541" alt=""
data:image/s3,"s3://crabby-images/d064f/d064f43941b99f7808983f109f2533f64fda5a70" alt=""
On “Configure group size and scaling policies”.
data:image/s3,"s3://crabby-images/f5ae7/f5ae7246f090b4a2327486fe3bd350466f919f6a" alt=""
data:image/s3,"s3://crabby-images/e6729/e672981c22eb9de19378d161b04a4871b0dd1a20" alt=""
data:image/s3,"s3://crabby-images/77ac2/77ac290919d34227bb7afe4c46f369689647d1f8" alt=""
Both WP instances have been automatically created via the AutoScaling group.
data:image/s3,"s3://crabby-images/6d979/6d97918e2bbdfb95d1c370b17e4b9587108a617a" alt=""
Go to the load balancer.
data:image/s3,"s3://crabby-images/43722/43722f195407487c750fb1bec0af36ff49241c67" alt=""
Click edit to create a new listener for port 443.
data:image/s3,"s3://crabby-images/61418/6141893f681d68bf4b6c3192d25b45fabf60c7cb" alt=""
Create a new target group for HTTPS.
data:image/s3,"s3://crabby-images/d5184/d5184cc1b4c6fafb399e68c9a6f95efa6365df32" alt=""
data:image/s3,"s3://crabby-images/96014/9601497a1f03ff96a2874c1dc3ceed78e3049c28" alt=""
Click Next.
data:image/s3,"s3://crabby-images/4e03b/4e03b5a4c0533ee723a32fc010113792fc9ebbd4" alt=""
Select both instances, and select “include as pending below”. Then, click “create target group”.
data:image/s3,"s3://crabby-images/2005a/2005a456fcb30f27910cd7153ff1bca52ecf6b1e" alt=""
data:image/s3,"s3://crabby-images/c38da/c38da02bb0f520f6134f837f4293aced56d42895" alt=""
Go back and change the listener.
data:image/s3,"s3://crabby-images/e6665/e666585ec879ed8dc12eb21fe009eda5d444aa6c" alt=""
data:image/s3,"s3://crabby-images/7d873/7d87395fc41f0f1e84abc2f82752ac99698bc84f" alt=""
Select “Request new ACM certificate” for ALB instance.
data:image/s3,"s3://crabby-images/1a93e/1a93ee414699da31f8ce077f3822b8df97238d0a" alt=""
Click “Request a certificate”.
data:image/s3,"s3://crabby-images/33291/332914c26348954785bd8ae60f0b12160c989c73" alt=""
data:image/s3,"s3://crabby-images/b83bd/b83bd4d7e4f688bf8c1f3729f5fac0ef3ad6ed41" alt=""
Enter your domain: alb.tungle.ca.
data:image/s3,"s3://crabby-images/45c8d/45c8ded00787b4d1c3d638c651d7e2dca5187b13" alt=""
data:image/s3,"s3://crabby-images/23ea6/23ea6f6e96d8518ec1a09d265a34f4fc5543ebcb" alt=""
Go to your hosting DNS domain name.
Create a CNAME record is alb with Amazon ALB domain name as a screenshot below.
data:image/s3,"s3://crabby-images/1a1e1/1a1e12e8957c27297eadbf43ce6e7baee6627eb0" alt=""
Copy and paste information on the Amazon certificate into your CNAME record.
data:image/s3,"s3://crabby-images/fd530/fd5302ec665fc9cef920771e2e3f604b485f39b8" alt=""
Checking domain via nslookup command.
data:image/s3,"s3://crabby-images/7533b/7533b06b9a7c89e1e213f9361be1d17041e8e4c5" alt=""
Back to configure listener setting, and choose the certificate that has been issued from AWS.
data:image/s3,"s3://crabby-images/08aee/08aee5ecd7cee41416db0baee04f65960ff494ad" alt=""
data:image/s3,"s3://crabby-images/a4afa/a4afac49e65a0fff900b48860af0cd3030c7e7d8" alt=""
Delete the unnecessary HTTP listener.
data:image/s3,"s3://crabby-images/64aa6/64aa636866f6ae825c81c95953c9cb00d1780d55" alt=""
data:image/s3,"s3://crabby-images/44dc8/44dc800bf4e1bc0c97925c6b0c56660082cf30d0" alt=""
Add the new listener on ALB to redirect port 80 to port 443.
data:image/s3,"s3://crabby-images/a4756/a47563532c8b988637cd7dcbf7b5b87832853f9d" alt=""
data:image/s3,"s3://crabby-images/cdbae/cdbaef7b953fd19f51ff6b4477b958d34e327217" alt=""
data:image/s3,"s3://crabby-images/490ef/490ef9ca886fcdd26874a275028684c79b05ad01" alt=""
Check target groups and verify both instances have healthy status on registered targets.
data:image/s3,"s3://crabby-images/82803/82803cca10a73a634e1af32cbd9c6810d7ee5c80" alt=""
Access the ALB web link on your web browser.
data:image/s3,"s3://crabby-images/1f5a2/1f5a2caf1dd80c817b9dfbd2174a2358d0825107" alt=""
data:image/s3,"s3://crabby-images/0ef9e/0ef9e16c0399a448e73d0f5afc45941c8f862cbb" alt=""
Check load balancing on both WPs.
data:image/s3,"s3://crabby-images/ff792/ff79295a047932922dc6e0c7664998c04bb2481c" alt=""
Refresh the web link.
data:image/s3,"s3://crabby-images/be103/be103e9ad053bf76d42ee897b919a94e9b0dfc6d" alt=""
Both WPS have accessed the same RDS instance (the master) on the IP address 10.0.2.224.
data:image/s3,"s3://crabby-images/7babc/7babcc01811ac9881b57a6ffd0b9039d436abe06" alt=""
Go to Amazon CloudFront to create CloudFront distribution.
data:image/s3,"s3://crabby-images/a3ba8/a3ba83a62dc706d61004169ac9fbb34bf1fdf748" alt=""
Enter your domain on the origin domain.
data:image/s3,"s3://crabby-images/25494/2549491a5482aca724976f692079578f8665b815" alt=""
data:image/s3,"s3://crabby-images/c727f/c727f3ed50796325a68d4a0853572caf4890ca85" alt=""
data:image/s3,"s3://crabby-images/86b47/86b479cfe5080f19043f15205aef5c8da6a70f3e" alt=""
Select your certificate on “the custom SSL certificate”.
data:image/s3,"s3://crabby-images/9868f/9868f774406b5b3368a8f3017153e13dcf72253e" alt=""
Leave the other settings default, then click Create distribution.
data:image/s3,"s3://crabby-images/e275d/e275d6c9c6171f0be334d4dba7f50e501b090217" alt=""
data:image/s3,"s3://crabby-images/b0fd9/b0fd93d31d21a8adf1a9fc8201fdd080c072fd15" alt=""
data:image/s3,"s3://crabby-images/e6b0b/e6b0b95c11d031758924f58ef2826f07febae185" alt="Image"
data:image/s3,"s3://crabby-images/00f4c/00f4c60e13e631f83bc6be727acc065f672addb2" alt=""
Access your CloudFront domain.
data:image/s3,"s3://crabby-images/f1026/f1026cc3fac9ca9ea178474e0550cd8c9dad7267" alt="Image"
data:image/s3,"s3://crabby-images/a0a01/a0a01d5109a3e176be185fe258cc4f6461c3fede" alt="Image"