Deploying a Webstudio Project with Flightcontrol
Webstudio is an open source website builder for creating highly maintainable and fast websites using modern web standards. This guide will provide detailed steps on how to deploy your Webstudio site to AWS with Flightcontrol.
At the end of this guide, we will have a Webstudio site deployed on AWS Elastic Container Service (ECS). It will have a publicly accessible URL and run on resources within your AWS account.
Prerequisites
- Create a Webstudio account
- Create a Flightcontrol account
- Create an AWS account
- Create a GitHub account
1. Create a GitHub repository
Create a repository where you will add the Webstudio Project code in the following steps. Be sure to clone the repository to your local machine.
2. Export Webstudio Project
Use the Webstudio CLI to export your Project and select the “Docker” option.
data:image/s3,"s3://crabby-images/da28b/da28b1da5ad2fa3aa4e25ea4a86444f219726dc8" alt="Selecting Docker for Webstudio"
3. Push to GitHub
Now that the site code is local, push it to GitHub.
You do not need to install dependencies.
4. Setup Flightcontrol
- Follow the prompt to connect AWS, which will direct you to AWS. Then click “Create stack”. It may take a couple of minutes, but once it is done, Flightcontrol will take you to the next step.
data:image/s3,"s3://crabby-images/7c370/7c370f92f77ddae5e8a8831407276d1e4eb9931f" alt="AWS setup in Flightcontrol"
- Connect your GitHub account and select the repository you want to give it permission to.
data:image/s3,"s3://crabby-images/11647/1164710b28f3a0ddf47cbe39239377c693f41f8d" alt="Connect GitHub button"
- Follow the prompts: Select “Build your own” > Select “Web server” > and select “Dockerfile” in “Build Configuration”.
data:image/s3,"s3://crabby-images/7d87b/7d87bb3cae3f80c1aecfa4fcf6e5bb520e8a07e0" alt="Build your own option"
- Deploy and wait. The initial deployment takes some time. Please allow up to ~15 minutes for the deployment to finish.
data:image/s3,"s3://crabby-images/4feb8/4feb8db3e16c7b45896ce39b30ac7d9b240dcefb" alt="Deployed app"
- (Optional) If you are loading images from third-party domains, usually in the case of CMS integrations, you must specify those asset domains in the Environment Variables tab with the key
DOMAINS
and a comma-separated list of the third-party domains. It’s best to inspect your HTML/API response to see the exact domain the platform is using.
data:image/s3,"s3://crabby-images/1e761/1e7618454016b1e8422af7d886838121b6bb7714" alt="Adding third party domains to flightcontrol"
5. Sync, Build, and push new changes
When you are ready to publish your latest changes again, follow these steps:
- Click “Publish” in the Webstudio builder (even though you aren’t publishing to the cloud, it’s necessary to generate the latest build data).
- Run
webstudio sync
- Run
webstudio build --template docker
- Push the changes to GitHub
data:image/s3,"s3://crabby-images/de8ea/de8ea9c21982d34eda0874941f847860667799ab" alt="Webstudio sync command"
Now, you should have a website built on Webstudio that is hosted on AWS using Flightcontrol.