Steps to deploy Strapi application on Azure Linux App Service (Preview)
Introduction
Strapi is an open-source, headless CMS that is highly customizable and developer-friendly, making it a popular choice for content management. When it comes to Strapi hosting, deploying Strapi, or self hosting Strapi, Azure App Service stands out as a premier solution. Azure App Service is a fully managed platform for building, deploying, and scaling web apps, offering unparalleled scalability and reliability.
In this quick start guide, you will learn how to create and deploy your first Strapi site on Azure App Service Linux, using Azure Database for MySQL or PostgreSQL, along with other necessary Azure resources.
What is Strapi on App Service?
App Service is a fully managed platform for building, deploying, and scaling web apps. Deploying Strapi on App Service brings together the power of Strapi's flexible content management capabilities with the scalability and reliability of Microsoft's cloud infrastructure.
This offering integrates key Azure services such as:
- Azure App Service
- Azure Database for MySQL flexible server or PostgreSQL flexible server
- Azure Email communication service
- Azure Virtual Network (VNET)
- Azure Blob Storage
- Azure Managed Identity
- Azure Key Vault
For more information read our Strapi on App Service overview blog.
Prerequisites
Before you deploy, customize, and consume this solution,
- You need an Azure account with an active subscription. Create an account for free.
- Most of the times, you won’t need to make changes to our ready to deploy ARM templates. However, if you want to make changes you would need basic understanding of Azure Resource Manager (ARM) templates
Deploy Strapi app
You can deploy Strapi via the following ways,
- Azure portal (recommended)
- Azure CLI
- Azure PowerShell
Steps to deploy via Azure portal
- Go to portal.azure.com and sign in.
- Navigate to the Azure Marketplace page for Strapi on App Service, and click on create.
- Provide Project details and Instance details
- Select your subscription.
- Create a new resource group (e.g., MyStrapiApp-RG).
- Choose an appropriate region for your Azure resources (e.g., East US).
- Provide an app name for Strapi application (e.g., MyStrapiApp).
- Select a database client (PostgreSQL or MySQL). Refer to the Strapi blog for guidance.
- Set an admin username and password for the database and confirm the password.
- Configure storage account public access. By default, it is set to true, meaning media asset URLs are publicly accessible. Set it to false to enhance security and restrict access to authorized users only.
- Choose the geographic location for your email data used by Azure Communication Service to send emails. Select a location that meets your compliance and data residency requirements.
4. Select Strapi application environment mode,
- 
- Development (recommended for Beginners): Use this mode when you are starting, developing, or testing your Strapi application. In this mode, you can directly update the content schema and data from Strapi admin portal. The Strapi App Service demo template package will be deployed by default to App Service.
- Production: For production mode, no default code or package will be deployed. You need to install Strapi locally and set up CI/CD. Here are the steps for that:
 
Read more in FAQ documentation for details on application modes and transitioning from development to production mode.
Note: The default pricing plans for Azure services used in this solution vary between development and production modes. You can adjust the pricing plan of respective resources post creation or by modifying the ARM template.
5. Initiate deployment
- 
- Click on Review + Create.
- Click on Create and wait for the confirmation of Azure resource provision and deployment.
- Click on Go to resource group to navigate to the App Service resource overview page.
- Click on your App Service resource to go to the overview page.
 
6. Set up admin account: On the App Service overview page click and navigate to the default domain URL. It usually takes few minutes for this page to load for first time. Set up your admin account from this page. Please note that the first user visiting this page will be able to set up the admin account, so ensure you set it up before sharing this page.
Navigate to default domain URL
Welcome to Strapi - Set up admin account
Deploy via CLI
You can download the ARM template and follow the instructions provided to deploy it using the CLI.
Deploy via PowerShell
You can download the ARM template and follow the instructions provided to deploy it using PowerShell.
Technical details & architecture
To simplify the deployment and provisioning of a Strapi on App Service, we have developed a pre-configured ARM template and made small modifications to standard Strapi 5 website template available in Strapi App Service demo template package. Note: This template uses Strapi version 5.10.3
The solution (ARM template) deploys Strapi into Azure App Service, provisions Azure MySQL or PostgreSQL for database and uses Azure Blob Storage for assets. Other required Azure Resources are also created as required. This solution template (currently in Preview mode) is ideal for getting started and can also be used in production with some changes.
To install the required resources for hosting your Strapi application will incur costs for your Azure Subscription. For pricing details, please refer to our section on estimating pricing.
Strapi on App Service solution provisions following architecture,
Strapi on App Service architecture
Configuration options & considerations
- The above deployment template creates new Azure resources (e.g. App Service plan, Flexible MySQL server plan etc.) for easier configuration and deployment. However, if you have existing resources, please download and modify the ARM template and configure it to use existing resources. You can deploy modified ARM template using CLI, PowerShell or Azure portal.
- All the Azure resources are created in the same selected region. However, at times some Azure resources are not available in the selected region. And for such cases you can change default region for all resources or change the region of the specific resource.
- Template uses some default names for the required resources, and feel free to change the same in the ARM template.
- Template uses default pricing plans that is suitable to get started with Strapi installation on App Service. Once you are ready to deploy for production workload, please change to appropriate pricing plans of the respective resources.
- Please note that while you can use an Azure free account to get started, the template configuration you choose you may well require an upgrade to a paid account.
- By default, free version of Strapi app has been installed. For information on self-hosting license plan refer to Strapi official page here.
- Strapi supports MySQL, PostgreSQL among other databases. This template uses MySQL & PostgreSQL.
- 
Salt, keys, and secret values are automatically generated and securely stored in Azure Key Vault. If you need to modify any of these values, begin by assigning the "Key Vault Secrets Officer" role to the user. You can do this by following the steps outlined in the documentation for granting application access to Azure Key Vault using Azure RBAC. Additionally, if you're accessing the Key Vault from the public internet, ensure that public access is enabled. You can configure this by navigating to the Settings > Networking section in the Azure portal and updating the access settings accordingly. Once the role is assigned and access is configured, navigate to your Resource Group, select the Azure Key Vault resource, and go to the Secrets section under Objects. From there, you can view and update the relevant entries as needed. The following values are auto-generated and stored: - App Keys: A comma-separated list of secret keys (strings) to sign the session cookies. These are used by Strapi's session middleware.
- JWT Secret: The secret used to sign the JWT for Strapi's Users-Permissions plugin.
- Admin JWT Secret: The secret used to sign the JWT for the Strapi Admin panel.
- API Token Salt: Salt used to generate tokens for Strapi APIs. If not defined, authenticated API features may not work correctly.
- Transfer Token Salt: Salt used to generate transfer tokens for Strapi data transfer between instances. If not defined, transfer features will be disabled.
 
- 
For more information on JWT configuration, API tokens and Environment variables, please refer to the Strapi documentation. 
Recommended next steps to go to Production
This document mostly discusses steps to get started and set up a test or development environment. Below are recommended next steps to set up production environment.
- Change application mode to production & other related settings. Refer to FAQ documentation
- Set up CI/CD
- Set up Custom domains and SSL certificates
- Set up Staging slotsf or safe testing. Copy and set up SQL database for production different from development database.
- Set up Emails with custom domain
- Update default pricing plans & SKUs
- Set up scaling and reliability capabilities
Clean up resources
When no longer needed, you can delete the resource group, that would delete all related resources. Follow the steps here to delete the resource group.
Support and Feedback
The Strapi deployment templates shared in this blog post are not a managed solution. Strapi is a third-party software platform, and Microsoft Customer Support and Services (CSS) will not support the Strapi related issues. Microsoft only provides support for the underlying Azure infrastructure and the services used in the solution. If you need any assistance, feel free to open a support request through the Microsoft Azure portal. New support request - Microsoft Azure
We value your feedback and suggestions to help us enhance our solution. Please feel free to share your thoughts or start a conversation by emailing us at strapionappservice@microsoft.com
Related content
- Strapi on App Service - Overview
- Strapi on App Service - FAQ
- Azure App Service
- Azure Database for MySQL flexible server
- Azure Database for PostgreSQL flexible server
- Azure Communication Services Email
- Azure Blob storage
- Azure Virtual Network (VNET)
- Azure Managed Identity
- Official Strapi Documentation