I am writing this blog to explain how to set up a react application on the cloud front (CDN) using the s3 bucket.
Checklist…
- Check the version of Node JS & NPM
- React CLI Tool to build fresh react application — https://create-react-app.dev/docs/getting-started
- Setup S3 bucket on AWS & upload build
- Create a certificate from the AWS Certificate Manager and update the DNS record
- Create distribution (CDN) on AWS
- Update DNS record to add an alias for distribution on Route 53
- Demo
data:image/s3,"s3://crabby-images/59f99/59f99e87b3411553256acd65186c0739bd9b8d9b" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
1. Check the version of Node JS & NPM
data:image/s3,"s3://crabby-images/ab7a9/ab7a9602d995dceb24e8f2f38acc28e2dd23f902" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
If Node JS is not installed in your development machine then you can download it from here: https://nodejs.org/en/
You can use “nvm” ( node version manager ) to upgrade/downgrade the Node JS version easily, For more information please visit: https://github.com/nvm-sh/nvm/blob/master/README.md
2. React CLI Tool to build fresh react application
Refer to this document and build your fresh react application using npx create-react-app my-app
command,
If you’ve previously installed create-react-app
globally via npm install -g create-react-app
, we recommend you uninstall the
package using npm uninstall -g create-react-app
or yarn global remove create-react-app
to ensure that “npx” always uses
the latest version.
data:image/s3,"s3://crabby-images/5505c/5505c82e02d8f0385abbb7763e1ec09f3a8d203f" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
data:image/s3,"s3://crabby-images/43d07/43d07f3159e7ee9b2094d96fbccbe51ac9487fa7" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
data:image/s3,"s3://crabby-images/b64b1/b64b1dbb8c51905937e7306b58c9de76abc78d1b" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
Once your react application will run successfully you can run a yarn run build
command to generate a build
data:image/s3,"s3://crabby-images/c08ee/c08ee2156d87f2c181f4dc8041b752851fd9224d" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
3. Setup S3 bucket on AWS & upload build
- Log in with your AWS credentials
- Goto the S3 service
- Click on the “Create bucket” button
- Set a bucket name and other configurations if required
- Click on the “Create bucket” button at the bottom of the form
- Upload all the files and folders from the “build” directory of your project
data:image/s3,"s3://crabby-images/0680f/0680fae37353e6745ee676e1690fcba803cfa40e" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
If you click on the index.html file you will get an object URL like “https://demo-aws-s3-cdn.s3.ap-south-1.amazonaws.com/index.html”, but if you open it on your browser it won’t work the reason is our bucket is not publically accessible
data:image/s3,"s3://crabby-images/24403/24403141132baa01f4930417bc721c2898b20708" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
data:image/s3,"s3://crabby-images/ed893/ed8938ef429c0e5a5c8efaea3e138d65685088c6" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
4. Create a certificate from the AWS Certificate Manager and update the DNS record
You can review this document to get a detailed understanding of AWS Certificate Manager,
Steps…
- Change the region from the top bar and select “US East (N. Virginia)”
- Click on the “Request a certificate” button
- Write “Fully qualified domain name”
- Click on the “Request” button
data:image/s3,"s3://crabby-images/c928f/c928f433577d8ec85c4bc282c01efeed5565e344" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
- Go to the detail page of your requested certificate from the “Certificates” and create a record in “Route 53”
data:image/s3,"s3://crabby-images/7309f/7309f58f1c08f0d352f6269dc87319c5ec470160" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
- After some time status will be changed from “Pending verification” to “Issued”
- Now you can use this certificate in cloud front distribution
5. Create distribution (CDN) on AWS
- Goto the Cloud Front service
- Click on the “Create Distribution” button
- Choose “Origin domain”
- Select “Yes use OAI (bucket can restrict access to only CloudFront)”
- Select “Yes, update the bucket policy”
- Choose “Custom SSL certificate — optional”, The certificate which you created using AWS Certificate Manager
- “/index.html” will be the default root object — optional
data:image/s3,"s3://crabby-images/c5c26/c5c26e19d667d9a05d3149396be90613767efbee" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
data:image/s3,"s3://crabby-images/1a2d1/1a2d1d6568e44510920d5dad25073f0912ab4c76" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
- Once your distribution is enabled and deployed the last step is to create an alias of CDN in “Route 53”
6. Update DNS record to add an alias for distribution on Route 53
- Goto the Route 53 service
- Click on the “Create Record” button
- Choose “Simple Routing” from the route policy
- Click on the “Next” and Define the simple record as below
data:image/s3,"s3://crabby-images/99da4/99da4bdcde7f27d18bcb93cd211ecfc6ba33d8fb" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
https://demo.internetofweb.com will work for you but if you still face any issues with this URL then you can check the Object Ownership and select “ACLs enabled”
data:image/s3,"s3://crabby-images/ee515/ee515c3edef9330af02be474391fe832b8c79d70" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
data:image/s3,"s3://crabby-images/aa291/aa291223e780c59e370f6ca5f6f23e1c2dd44f7f" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
7. Demo
https://demo.internetofweb.com
data:image/s3,"s3://crabby-images/24b07/24b07ed761712de95877b0a4ace3eb594bf03817" alt="Unleash the Potential of Your React JS App: Effortlessly Deploy with AWS CloudFront CDN"
Thanks :-)
Murtaza Vohra