title | description | ms.assetid | ms.topic | ms.date |
---|---|---|---|---|
Continuous deployment for Azure Functions |
Use the continuous deployment features of Azure App Service to publish your functions. |
361daf37-598c-4703-8d78-c77dbef91643 |
conceptual |
09/25/2019 |
You can use Azure Functions to deploy your code continuously by using source control integration. Source control integration enables a workflow in which a code update triggers deployment to Azure. If you're new to Azure Functions, get started by reviewing the Azure Functions overview.
Continuous deployment is a good option for projects where you integrate multiple and frequent contributions. When you use continuous deployment, you maintain a single source of truth for your code, which allows teams to easily collaborate. You can configure continuous deployment in Azure Functions from the following source code locations:
The unit of deployment for functions in Azure is the function app. All functions in a function app are deployed at the same time. After you enable continuous deployment, access to function code in the Azure portal is configured as read-only because the source of truth is set to be elsewhere.
For continuous deployment to succeed, your directory structure must be compatible with the basic folder structure that Azure Functions expects.
[!INCLUDE functions-folder-structure]
Note
Continuous deployment is not yet supported for Linux apps running on a Consumption plan.
To configure continuous deployment for an existing function app, complete these steps. The steps demonstrate integration with a GitHub repository, but similar steps apply for Azure Repos or other source code repositories.
-
In your function app in the Azure portal, select Deployment Center, select GitHub, and then select Authorize. If you've already authorized GitHub, select Continue and skip the next step.
:::image type="content" source="./media/functions-continuous-deployment/github.png" alt-text="Azure App Service Deployment Center":::
-
In GitHub, select Authorize AzureAppService.
:::image type="content" source="./media/functions-continuous-deployment/authorize.png" alt-text="Authorize Azure App Service":::
Enter your GitHub password and then select Continue.
-
Select one of the following build providers:
- App Service build service: Best when you don't need a build or if you need a generic build.
- Azure Pipelines (Preview): Best when you need more control over the build. This provider currently is in preview.
Select Continue.
-
Configure information specific to the source control option you specified. For GitHub, you must enter or select values for Organization, Repository, and Branch. The values are based on the location of your code. Then, select Continue.
:::image type="content" source="./media/functions-continuous-deployment/github-specifics.png" alt-text="Configure GitHub":::
-
Review all details, and then select Finish to complete your deployment configuration.
When the process is finished, all code from the specified source is deployed to your app. At that point, changes in the deployment source trigger a deployment of those changes to your function app in Azure.
Note
After you configure continuous integration, you can no longer edit your source files in the Functions portal. If you originally published your code from your local computer, you may need to change the WEBSITE_RUN_FROM_PACKAGE
setting in your function app to a value of 0
.
[!div class="nextstepaction"] Best practices for Azure Functions