Deploying an Astro site to Azure Static Web Apps should be straightforward, but my initial experience was not pain-free. The default Oryx GitHub Action (Oryx GitHub Actions) failed due to package size issues and its reliance on an outdated npm install --production
command. To work around this, I updated the deployment process to use the Azure Static Web Apps CLI instead.
In this blog post, I’ll walk you through deploying an Astro site to Azure Static Web Apps using the Static Web Apps CLI, ensuring a smoother experience.
Step 1: Create an Astro site
In my scenario, I created a new folder and the Astro site in a subfolder named app
. I wanted to keep the root folder as clean as possible, and I will add an API folder with Azure Functions later.
|
|
infoAnswer the questions Houston asks you to fit your needs
Step 2: Install the Azure Static Web Apps CLI
The Azure Static Web Apps CLI is a command-line tool that allows you to create, manage, and deploy Azure Static Web Apps directly from your terminal. To install the CLI, run the following command:
|
|
infoYou can use the
swa
command locally to start your development server. Instead of the defaulthttp://localhost:4321
address, which you get from Astro, it will proxy all traffic through thehttps://localhost:4280
address (default configuration). The nice thing is that you can test your APIs and authentication/authorization as if they are running on Azure.
Step 3: Initialize the Azure Static Web Apps project
Next, initialize the Azure Static Web App in the project root:
|
|
It will provide you with a default config. You should not accept it and provide the following answers:
data:image/s3,"s3://crabby-images/b4ca4/b4ca4a5994408e5f49a9b40b8a410e2b541da112" alt="Static Web App CLI - Initialization"
The swa-cli.config.json
file contents it creates should look similar to this:
|
|
Step 4: Add the build and dev scripts to your package.json
On the root, I installed the npm-run-all
package to run the build and dev scripts in parallel and configured the build
and dev
scripts in the package.json
file:
|
|
Step 5: Test out the local development
With the above configuration, you should be able to start the local development server from Astro and the Azure Static Web Apps CLI:
|
|
data:image/s3,"s3://crabby-images/39da7/39da7d4adce90449649785fbe4e4e8ad27d063be" alt="Local development with the Static Web App server"
As you can see in the above screenshot, the Azure Static Web Apps proxy is running on https://localhost:4280
and the Astro development server on http://localhost:4321
. Suppose you do not use any local APIs or authentication/authorization. In that case, you can use the Astro development server only, but once you add these, it is recommended that you use the Azure Static Web Apps proxy. That way, you don’t have to think about CORS issues and can test your APIs as if they are running on Azure.
Once you are happy with the local development, you can commit your changes and push them to your GitHub repository.
Step 6: Create the Azure Static Web App
On Azure, I created a new Static Web App and provided the following information:
data:image/s3,"s3://crabby-images/472d7/472d79d90e1a6a9ae1ea0eb64230f71e71982bb2" alt="Azure Static Web App creation"
As you can see in the screenshot, I defined the app, API, and output location. I originally wanted to use the default GitHub Actions workflow it provided me, so I defined these values. As we will use the CLI, all the required values are already provided in the swa-cli.config.json
file.
When you connect the GitHub repository, it automatically creates a GitHub Actions workflow for you. We won’t be using this workflow except for the API token it generates.
Step 7: Update the GitHub Actions workflow
Once the Static Web App is created, you can pull the repository changes. In the` .github/workflows’ folder, you will see a new GitHub Actions workflow.
In my case, my first run failed due to the package size issues.
data:image/s3,"s3://crabby-images/a116a/a116ab18569e91b95b16123fde70ab49e4a5a98e" alt="GitHub Actions workflow failed"
Another thing I noticed was the warning about the npm install --production
command. You should use npm install --omit=dev
instead.
data:image/s3,"s3://crabby-images/3db7e/3db7e8660fd4ac17c4ff25a0b34eb511976059db" alt="npm install --production"
To address these issues and gain more control over the whole workflow, I decided to create a new GitHub Actions workflow and deploy the site using the Azure Static Web Apps CLI.
Change the GitHub Actions workflow filename to deploy.yml
and update the contents to the following:
|
|
importantReplace
<ID>
with the ID of the Azure Static Web App API token name that was created for your GitHub Actions workflow.
With this workflow, you can commit and push the changes to your GitHub repository. The GitHub Actions workflow will trigger the deployment to Azure Static Web Apps.
data:image/s3,"s3://crabby-images/63c26/63c2657485ad455e7a87bc8104147b1c9afdd7d9" alt="Successful deployment with GitHub Actions workflow"
Conclusion
Deploying an Astro site to Azure Static Web Apps can be challenging, especially with the default Oryx GitHub Action, which I initially struggled with due to package size limitations and outdated dependency handling. Switching to the Azure Static Web Apps CLI allows you more control over the whole build and deployment process.