Updated April 2023. I have updated this article to add more information about AWS Amplify.
This is a practical use case where I will explain step by step how I deployed my blog using Amplify Hosting. I will use the AWS Console to do it.
The source code of my blog (web) is available here
AWS Amplify is a set of purpose-built tools and features that enables frontend web and mobile developers to quickly and easily build full-stack applications on AWS.
Amplify provides two services: Amplify Hosting and Amplify Studio.
- Amplify Hosting provides a git-based workflow for hosting full-stack serverless web apps with continuous deployment.
- Amplify Studio is a visual development environment that simplifies the creation of scalable, full-stack web and mobile apps. Use Studio to build your frontend UI with a set of ready-to-use UI components, create an app backend, and then connect the two together.
AWS Amplify is the fastest and easiest way to develop and deploy reliable and scalable mobile/web applications on AWS
We need to have our code ready to be deployed in a supported repository.
- Supported repositories: GitHub, Bitbucket, GitLab and AWS CodeCommit.
- Another option is to deploy manually with drag and drop, Amazon S3 or any URL.
In AWS Console, enter to AWS Amplify service and choose
a) If you don’t have an Amplify app, this screen appears and you have to click on Get Started
and then choose Amplify Hosting
b) If you already have an Amplify resource click on New app and Host web app
Configure Amplify Hosting:
In the following lines, we will review how to apply additional configuration to add more value to our website.
We can also set up our Domain Name to our deployed website with Amplify Hosting easily.
To register the domain name I used Amazon Route53.
Use Route53 is not the cheapest option (e.g. I paid $12 to register the new domain with Route53 instead of $1 the first year with GoDaddy), but it’s worth it (to me)
In the side menu, click Domain management, and then click Add domain.
Choose your Domain and click on Save. As I register my domain with Route53, it appears in the text field when I click on it.
Now you can choose the branch, the subdomains and check for automatic redirect from HTTP to HTTPS, and click Save.
It may take several minutes to complete. First, you need to create the SSL certificate, then configure the SSL and finally activate it.
If we access the main page we can see that the URL has changed.
We can now access it with our domain name:
That’s it, quick and easy!
Configuring AWS Amplify Hosting to deploy several versions of the website is very easy, you just need different branches in the repository and configure them in the service as follows:
Using the preview feature you can preview changes before merging a pull request.
To do that you have to:
- Create a new branch
previewsand associate with your branch
- Open a pull request –> A new version of the application will be deployed
If you want to protect any environment to don’t be accessible by everyone, you can use the feature of Access Control. With this option, you can create a simple user/password to restrict access to your web:
There are only 2 options for the option
- Publicly available
- Restricted - password required
When you try to access now to the web you have to log in yo view the content: