DEV Community

Cover image for Deploying a Static Web Application Using AWS S3 and CloudFront
Farhan Ramzan
Farhan Ramzan

Posted on • Edited on

Deploying a Static Web Application Using AWS S3 and CloudFront

In the realm of modern web development, deploying static web applications efficiently and securely is crucial. AWS(Amazon Web Services) offers a powerful combination of S3 and CloudFront that simplifies and optimizes this process. In this guide, we'll walk through the steps to deploy a static react web application using the S3 and cloudfront, then we will use code build to automate its deployment.

Amazon S3:
Amazon Simple Storage Service(S3) is a highly scalable, secure, and durable object storage service. It's an ideal solution for hosting static web content like HTML, CSS, JavaScript, images, and more.

CloudFront:
AWS CloudFront is a content delivery network (CDN) service that accelerates the delivery of your web content globally. It distributes your content through a network of edge locations to reduce latency and enhance user experience.

Steps to Deploy:

1. Create React App:

  • Let's create the react app named "deploy-app" using the following command: npx create-react-app deploy-app
  • Move to the folder: cd deploy-app
  • Build the react app using: npm i npm run build this will create a folder /build at root that can be serve to access the app.

2. Upload to Github:

  • Create the repo "delpoy-app" on your github.
  • Add the buildspec.yaml and place the below content in it in your local code(this will be used later in this tutorial)
version: 0.2
phases:
  pre_build:
    commands:
      - echo Installing node packages
      - npm i
  build:
    commands:
      - echo Build started on `date`
      - npm run $ENV
  post_build:
    commands:
      - aws s3 sync build/ $BUCKET_NAME
      - aws cloudfront create-invalidation --distribution-id $DISTRIBUTION_ID --paths '/*'
Enter fullscreen mode Exit fullscreen mode

Push the local changes on github using the following commands:
git init
git remote add origin https://github.com/USERNAME/deploy-app.git
git add .
git commit -m 'added buildspec.yaml for automation'
git push origin main

3. Create AWS S3 bucket:
On AWS console move to S3 and create bucket,

  • Select AWS region
  • Enter the Bucket name
  • Uncheck the "Block all public access"
  • leave the rest of the settings default and press Create Bucket
    Image description

  • Once it is created then select "Properties", scroll down to bottom, "Edit" the static website hosting and set the below settings and press "Save changes",
    Image description

  • Then, select "Permissions", then "Edit" the Bucket policy, add the following content(remember to update the BUCKET_NAME) and Save Changes,

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Sid": "PublicReadGetObject",
            "Effect": "Allow",
            "Principal": "*",
            "Action": "s3:*",
            "Resource": [
                "arn:aws:s3:::BUCKET_NAME/*",
                "arn:aws:s3:::BUCKET_NAME"
            ]
        }
    ]
}
Enter fullscreen mode Exit fullscreen mode
  • Now add the content of /build folder on S3 bucket.
    Image description

  • Now the static app will be accessible on the S3 static url,
    Image description

4. Attach Cloudfront with S3:
To access the static content from S3 with high speed and less latency we will attach the cloudfront with S3 bucket. To do so, move to Cloudfront from AWS console.

  • Press the "Create Distribution"
  • Copy the static url from the s3 bucket properties and place it in the origin domain for cloudfront. Don't forget to remove the https:// from the s3 bucket static url. Image description

Image description

  • Then, select the Redirect HTTP to HTTPS and set the Allowed HTTP methods:
    Image description

  • Then press "Create Distribution"

  • Once the distribution is created, you will be able to access the react app on Distribution domain name:
    Image description

Image description

5. CodeBuild for deployment on S3:
To automate the deployment process for react app whenever the code is pushed in particular on the github we can use the CodeBuild pipeline. Let's automate this process for "main" branch.

  • On AWS console move to CodeBuild.
  • Press Create build project.
  • Enter the name for project.
  • Add source(in our case it will be github) and connect your repository and select the branch. Image description
  • Then enable the "webhook and add the following settings" so that whenever the code is pushed to the main branch this pipeline gets triggered. Image description
  • Create a Service Role and also add the "CloudFrontFullAccess" permission in this IAM role once the role is created. This will be needed to create the invalidator. Image description
  • In Addition Configurations add the following Environment variables that are being used in buildspec.yaml we created above.

Image description

  • Press "Create build project"
  • Once it is created press "Start Build". This will get the latest code from main branch, build the project, sync the build folder with s3 bucket and create the invalidator. Now, whenever there will be a new commit in github repo in main branch this pipeline will trigger that deploy the latest code to s3 bucket.

Happy Learning...

Blog for setting up a kubernetes kind cluster:
https://medium.com/@farhanramzan799/setting-up-a-kubernetes-cluster-with-kind-316d1dda566d

Top comments (2)

Collapse
 
ehsanilahi22 profile image
Ehsan Ilahi Sindhu

Good Effort

Collapse
 
farhanramzan799 profile image
Farhan Ramzan

Thankyou