In this CloudFront Distribution how-to-do we will cover following tasks :
- Create a Cloudfront distribution for the images that are uploaded on a WordPress blog.
- Automatically sync wordpress uploads to s3 bucket.
- Compare the image load time across different countries with and without cloudfront.
Step 1 : Create a Bucket
Step 2 : Create the CloudFront Distribution
data:image/s3,"s3://crabby-images/73bf7/73bf73704f2e44363f9f17038f8490690a9e7d57" alt="create-cnd"
data:image/s3,"s3://crabby-images/06f44/06f4429b8c4ea91590e97df15fe600bef001925e" alt="create-cdn2"
data:image/s3,"s3://crabby-images/12f49/12f492143c17ebffd68ff7dadc485da5d4001de7" alt="create-cdn3"
data:image/s3,"s3://crabby-images/2b2ac/2b2ac7ceab1e1cf52c2bccd52cb55dc777f186fb" alt="create-cdn4"
Step 3 : Create the new Cronjob
Note: In order to perform further steps its recommended to configure AWS CLI on EC2 instance before moving on further.
data:image/s3,"s3://crabby-images/73b3f/73b3facd6416dc493ad7caa2b8e8e962947bd085" alt="Create a cronjob to sync all the s3 bucket content"
*/2 * * * * root aws s3 sync /var/www/html/wp-content/uploads s3://wp-cdn1
Step 4 : Add new post to WordPress with Image
data:image/s3,"s3://crabby-images/43a26/43a264ac3e5411273eb5f34a4b51447f4c686d67" alt="create-post-cdn"
Step 5 : Redirect uploads folder to our CloudFront Distribution
data:image/s3,"s3://crabby-images/0a624/0a62445d949fa3b9dcc57b94db5a1be1eeb9367b" alt="rewrite-rule"
rewriterule ^wp-content/uploads/(.*)$ http://dsnbd65zem3ul.cloudfront.net/$1 [r=301, nc]
Step 6 : Restart crond and httpd service
data:image/s3,"s3://crabby-images/9d469/9d469b2b2bdd2cffe7a05e9d4c17b6e66bfb1054" alt="restart-cron-job"
Step 7 : Testing our Cloudfront Distribution
data:image/s3,"s3://crabby-images/5aaeb/5aaebe06b0759f65f7eb805456f45ea0d26a5fa7" alt="Test the CDN, If everything is properly configured the URL of the image will be changed to CDN's URL"
Step 8 : Latency Test (without Cloudfront)
data:image/s3,"s3://crabby-images/c9d41/c9d415eb0f9ebf435352dd7a6c1b520d41be96a5" alt="You can find many online tools to test website latency. select any as you like and enter the ip address for your wordpress website"
Here you can see the result without cloudfront
Step 9 : Latency Test (with Cloudfront)
data:image/s3,"s3://crabby-images/5b4f2/5b4f2b168c32b9f415efa51ffb703eebf5ed0713" alt="With CND implemented you can see it has decreased latency, thus proving the advantage of have a CDN configured for all the static content of a website"
With CDN implemented you can see it has decreased latency of website, thus this proves the advantage of having a CDN configured for all the static content on a wesbite.
Feel free to ask any queries in comments below.
Thanks for reading, hope it helped!
-bhargav
Social Profiles