data:image/s3,"s3://crabby-images/41f53/41f53b3f99010b382e0d6900f600f7aa0aa80897" alt="Publishing Your Next Gatsby Site to AWS With AWS Amplify"
In this post, we'll walk through how to host & publish your next Gatsby site to AWS using AWS Amplify.
AWS Amplify is a combination of client library, CLI toolchain, UI components & CI / CD hosting platform. Amplify allows developers to get up & running with full-stack cloud-powered applications with features like authentication, GraphQL, storage, REST APIs, analytics, Lambda functions, hosting & more.
Using the Amplify console, you can now easily deploy your application to AWS with built in CI / CD & atomic deployments.
Getting Started - Gatsby
First, we'll want to create a new Gatsby project. If you don't already have Gatsby installed, install it:
Next, we’ll create a new Gatsby site:
Finally, change into the new site directory:
Getting Started - AWS Amplify
Now that we have our Gatsby site up & running, let's add hosting & make the site live on AWS.
To do so, create a new GitHub repo & push the project to the repo.
Now that the GitHub project has been created we can log into the Amplify Console.
From here, under Deploy we can click GET STARTED:
data:image/s3,"s3://crabby-images/621c9/621c98b0330c4fbd7d50241c767cfb126150d541" alt="Amplify Console"
Next, we'll choose GitHub as our repository & click Next.
data:image/s3,"s3://crabby-images/ed4da/ed4da5a0edbc39ab3c15f0f3a8ff19c8e1235bc3" alt="Choosing repo"
Then connect the mater branch of the new repo we just created & click Next:
data:image/s3,"s3://crabby-images/cd953/cd95332d8a7e98f606b7ad0145a7930c8aaabab1" alt="Choosing branch"
In this view, we can review the default build settings & click Next to continue:
data:image/s3,"s3://crabby-images/e932a/e932ac91596e4be4bdebf2f92fbc0ffab6923a2b" alt="Build settings"
Finally, we can review the deployment & click Save & Deploy when we're ready to deploy our app:
data:image/s3,"s3://crabby-images/fc5d4/fc5d42c41b5cebd05f093bf559d4368a06322574" alt="Deploying"
Once the deployment is successful, you should see this:
data:image/s3,"s3://crabby-images/02b0a/02b0aa8cef9ab69f8d508f8e786e49c918f901fa" alt="Successful deployment"
To view details of the deployment, click on the name of the branch (in our case, master).
In this view, you can see details about the deployment including a link to view the app & screenshots of the app on different devices.
data:image/s3,"s3://crabby-images/cdf5a/cdf5a5a8d87929c77a948260be9004c2b4696359" alt="Deployment details"
Kicking off a new build
Now that our app is deployed, let's take it one step further. The Amplify Console will automatically watch your master branch & kick off a new build whenever new code is merged. Let's test this out.
Open src/pages/index.js
& replace the following line:
with this:
Save the file & push the changes to your master branch:
Now, when we go back into the Amplify console we’ll see that a new build has been started:
data:image/s3,"s3://crabby-images/6c141/6c1411870eb6bbe383dfa47c5c02661e1e978deb" alt="New build"
When the build is completed & we launch the app, we should now see our new heading:
data:image/s3,"s3://crabby-images/c9742/c9742ef967e8a59e4b62b30f3ff0f272d1e19987" alt="New build completed"
Next Steps
Now that you've gotten the hang of working with the Amplify Console, what are some next steps?
If you're interested in adding authentication to your Gatsby app, check out this Gatsby Auth Starter I published.
If you're interested in adding new features to your Gatsby app (like authentication or a GraphQL API), check out the Amplify CLI & Amplify Client libraries.
You may also be interested in working with multiple environments or teams. If so, check out the documentation on how to get up & running with teams or have a look at this post that I wrote.