AspNetCore.Docs/aspnetcore/host-and-deploy/azure-apps/index.md

193 lines
13 KiB
Markdown
Raw Normal View History

---
title: Host ASP.NET Core on Azure App Service
author: guardrex
description: Discover how to host ASP.NET Core apps in Azure App Service with links to helpful resources.
2018-01-29 23:21:31 +08:00
ms.author: riande
ms.custom: mvc
2018-08-31 01:13:25 +08:00
ms.date: 08/29/2018
uid: host-and-deploy/azure-apps/index
---
# Host ASP.NET Core on Azure App Service
[Azure App Service](https://azure.microsoft.com/services/app-service/) is a [Microsoft cloud computing platform service](https://azure.microsoft.com/) for hosting web apps, including ASP.NET Core.
## Useful resources
The Azure [Web Apps Documentation](/azure/app-service/) is the home for Azure Apps documentation, tutorials, samples, how-to guides, and other resources. Two notable tutorials that pertain to hosting ASP.NET Core apps are:
[Quickstart: Create an ASP.NET Core web app in Azure](/azure/app-service/app-service-web-get-started-dotnet)
Use Visual Studio to create and deploy an ASP.NET Core web app to Azure App Service on Windows.
[Quickstart: Create a .NET Core web app in App Service on Linux](/azure/app-service/containers/quickstart-dotnetcore)
Use the command line to create and deploy an ASP.NET Core web app to Azure App Service on Linux.
The following articles are available in ASP.NET Core documentation:
[Publish to Azure with Visual Studio](xref:tutorials/publish-to-azure-webapp-using-vs)
Learn how to publish an ASP.NET Core app to Azure App Service using Visual Studio.
[Publish to Azure with CLI tools](xref:tutorials/publish-to-azure-webapp-using-cli)
Learn how to publish an ASP.NET Core app to Azure App Service using the Git command-line client.
[Continuous deployment to Azure with Visual Studio and Git](xref:host-and-deploy/azure-apps/azure-continuous-deployment)
Learn how to create an ASP.NET Core web app using Visual Studio and deploy it to Azure App Service using Git for continuous deployment.
[Create your first pipeline with Azure Pipelines](/azure/devops/pipelines/get-started-yaml)
Set up a CI build for an ASP.NET Core app, then create a continuous deployment release to Azure App Service.
[Azure Web App sandbox](https://github.com/projectkudu/kudu/wiki/Azure-Web-App-sandbox)
Discover Azure App Service runtime execution limitations enforced by the Azure Apps platform.
::: moniker range=">= aspnetcore-2.0"
## Application configuration
In ASP.NET Core 2.0 or later, the following NuGet packages provide automatic logging features for apps deployed to Azure App Service:
* [Microsoft.AspNetCore.AzureAppServices.HostingStartup](https://www.nuget.org/packages/Microsoft.AspNetCore.AzureAppServices.HostingStartup/) uses [IHostingStartup](xref:fundamentals/configuration/platform-specific-configuration) to provide ASP.NET Core light-up integration with Azure App Service. The added logging features are provided by the `Microsoft.AspNetCore.AzureAppServicesIntegration` package.
* [Microsoft.AspNetCore.AzureAppServicesIntegration](https://www.nuget.org/packages/Microsoft.AspNetCore.AzureAppServicesIntegration/) executes [AddAzureWebAppDiagnostics](/dotnet/api/microsoft.extensions.logging.azureappservicesloggerfactoryextensions.addazurewebappdiagnostics) to add Azure App Service diagnostics logging providers in the `Microsoft.Extensions.Logging.AzureAppServices` package.
* [Microsoft.Extensions.Logging.AzureAppServices](https://www.nuget.org/packages/Microsoft.Extensions.Logging.AzureAppServices/) provides logger implementations to support Azure App Service diagnostics logs and log streaming features.
If targeting .NET Core and referencing the [Microsoft.AspNetCore.All metapackage](xref:fundamentals/metapackage), the packages are already included. The packages are absent from the newer [Microsoft.AspNetCore.App metapackage](xref:fundamentals/metapackage-app). If targeting .NET Framework or referencing the `Microsoft.AspNetCore.App` metapackage, reference the individual logging packages.
::: moniker-end
2018-08-25 03:10:45 +08:00
## Override app configuration using the Azure Portal
The **App Settings** area of the **Application settings** blade permits you to set environment variables for the app. Environment variables can be consumed by the [Environment Variables Configuration Provider](xref:fundamentals/configuration/index#environment-variables-configuration-provider).
When an app uses the [Web Host](xref:fundamentals/host/web-host) and builds the host using [WebHost.CreateDefaultBuilder](/dotnet/api/microsoft.aspnetcore.webhost.createdefaultbuilder), environment variables that configure the host use the `ASPNETCORE_` prefix. For more information, see <xref:fundamentals/host/web-host> and the [Environment Variables Configuration Provider](xref:fundamentals/configuration/index#environment-variables-configuration-provider).
When an app uses the [Generic Host](xref:fundamentals/host/generic-host), environment variables aren't loaded into an app's configuration by default and the configuration provider must be added by the developer. The developer determines the environment variable prefix when the configuration provider is added. For more information, see <xref:fundamentals/host/generic-host> and the [Environment Variables Configuration Provider](xref:fundamentals/configuration/index#environment-variables-configuration-provider).
## Proxy server and load balancer scenarios
The IIS Integration Middleware, which configures Forwarded Headers Middleware, and the ASP.NET Core Module are configured to forward the scheme (HTTP/HTTPS) and the remote IP address where the request originated. Additional configuration might be required for apps hosted behind additional proxy servers and load balancers. For more information, see [Configure ASP.NET Core to work with proxy servers and load balancers](xref:host-and-deploy/proxy-load-balancer).
## Monitoring and logging
For monitoring, logging, and troubleshooting information, see the following articles:
[How to: Monitor Apps in Azure App Service](/azure/app-service/web-sites-monitor)
Learn how to review quotas and metrics for apps and App Service plans.
[Enable diagnostics logging for web apps in Azure App Service](/azure/app-service/web-sites-enable-diagnostic-log)
Discover how to enable and access diagnostic logging for HTTP status codes, failed requests, and web server activity.
[Introduction to Error Handling in ASP.NET Core](xref:fundamentals/error-handling)
Understand common approaches to handling errors in ASP.NET Core apps.
[Troubleshoot ASP.NET Core on Azure App Service](xref:host-and-deploy/azure-apps/troubleshoot)
Learn how to diagnose issues with Azure App Service deployments with ASP.NET Core apps.
[Common errors reference for Azure App Service and IIS with ASP.NET Core](xref:host-and-deploy/azure-iis-errors-reference)
See the common deployment configuration errors for apps hosted by Azure App Service/IIS with troubleshooting advice.
## Data Protection key ring and deployment slots
[Data Protection keys](xref:security/data-protection/implementation/key-management#data-protection-implementation-key-management) are persisted to the *%HOME%\ASP.NET\DataProtection-Keys* folder. This folder is backed by network storage and is synchronized across all machines hosting the app. Keys aren't protected at rest. This folder supplies the key ring to all instances of an app in a single deployment slot. Separate deployment slots, such as Staging and Production, don't share a key ring.
When swapping between deployment slots, any system using data protection won't be able to decrypt stored data using the key ring inside the previous slot. ASP.NET Cookie Middleware uses data protection to protect its cookies. This leads to users being signed out of an app that uses the standard ASP.NET Cookie Middleware. For a slot-independent key ring solution, use an external key ring provider, such as:
* Azure Blob Storage
* Azure Key Vault
* SQL store
* Redis cache
For more information, see [Key storage providers](xref:security/data-protection/implementation/key-storage-providers).
## Deploy ASP.NET Core preview release to Azure App Service
ASP.NET Core preview apps can be deployed to Azure App Service with the following approaches:
* [Install the preview site extension](#install-the-preview-site-extension)
2018-08-14 12:15:57 +08:00
<!-- * [Deploy the app self-contained](#deploy-the-app-self-contained) -->
* [Use Docker with Web Apps for containers](#use-docker-with-web-apps-for-containers)
2018-04-23 22:40:38 +08:00
### Install the preview site extension
2018-08-31 01:13:25 +08:00
If a problem occurs using the preview site extension, open an issue on [GitHub](https://github.com/aspnet/azureintegration/issues/new).
1. From the Azure portal, navigate to the App Service blade.
1. Select the web app.
2018-08-31 01:13:25 +08:00
1. Type "ex" in the search box or scroll down the list of management sections to **DEVELOPMENT TOOLS**.
1. Select **DEVELOPMENT TOOLS** > **Extensions**.
1. Select **Add**.
2018-08-31 01:13:25 +08:00
1. Select the **ASP.NET Core &lt;x.y&gt; (x86) Runtime** extension from the list, where `<x.y>` is the ASP.NET Core preview version (for example, **ASP.NET Core 2.2 (x86) Runtime**). The x86 runtime is appropriate for [framework-dependent deployments](/dotnet/core/deploying/#framework-dependent-deployments-fdd) that rely on out-of-process hosting by the ASP.NET Core Module.
1. Select **OK** to accept the legal terms.
1. Select **OK** to install the extension.
2018-08-31 01:13:25 +08:00
When the operation completes, the latest .NET Core preview is installed. Verify the installation:
1. Select **Advanced Tools** under **DEVELOPMENT TOOLS**.
1. Select **Go** on the **Advanced Tools** blade.
1. Select the **Debug console** > **PowerShell** menu item.
1. At the PowerShell prompt, execute the following command. Substitute the ASP.NET Core runtime version for `<x.y>` in the command:
```powershell
Test-Path D:\home\SiteExtensions\AspNetCoreRuntime.<x.y>.x86\
```
If the installed preview runtime is for ASP.NET Core 2.2, the command is:
```powershell
Test-Path D:\home\SiteExtensions\AspNetCoreRuntime.2.2.x86\
```
The command returns `True` when the x64 preview runtime is installed.
::: moniker range=">= aspnetcore-2.2"
> [!NOTE]
> The platform architecture (x86/x64) of an App Services app is set in the **Application Settings** blade under **General Settings** for apps that are hosted on an A-series compute or better hosting tier. If the app is run in in-process mode and the platform architecture is configured for 64-bit (x64), the ASP.NET Core Module uses the 64-bit preview runtime, if present. Install the **ASP.NET Core &lt;x.y&gt; (x64) Runtime** extension (for example, **ASP.NET Core 2.2 (x64) Runtime**).
>
> After installing the x64 preview runtime, run the following command in the Kudu PowerShell command window to verify the installation. Substitute the ASP.NET Core runtime version for `<x.y>` in the command:
>
> ```powershell
> Test-Path D:\home\SiteExtensions\AspNetCoreRuntime.<x.y>.x64\
> ```
> If the installed preview runtime is for ASP.NET Core 2.2, the command is:
> ```powershell
> Test-Path D:\home\SiteExtensions\AspNetCoreRuntime.2.2.x64\
> ```
> The command returns `True` when the x64 preview runtime is installed.
2018-08-31 01:13:25 +08:00
::: moniker-end
2018-08-31 01:13:25 +08:00
> [!NOTE]
> **ASP.NET Core Extensions** enables additional functionality for ASP.NET Core on Azure App Services, such as enabling Azure logging. The extension is installed automatically when deploying from Visual Studio. If the extension isn't installed, install it for the app.
**Use the preview site extension with an ARM template**
2018-04-23 23:10:07 +08:00
If an ARM template is used to create and deploy apps, the `siteextensions` resource type can be used to add the site extension to a web app. For example:
[!code-json[Main](index/sample/arm.json?highlight=2)]
2018-08-14 12:15:57 +08:00
<!--
### Deploy the app self-contained
A [self-contained app](/dotnet/core/deploying/#self-contained-deployments-scd) can be deployed that carries the preview runtime in the deployment. When deploying a self-contained app:
* The site doesn't need to be prepared.
* The app must be published differently than when publishing for a framework-dependent deployment with the shared runtime and host on the server.
Self-contained apps are an option for all ASP.NET Core apps.
2018-08-14 12:15:57 +08:00
-->
### Use Docker with Web Apps for containers
The [Docker Hub](https://hub.docker.com/r/microsoft/aspnetcore/) contains the latest preview Docker images. The images can be used as a base image. Use the image and deploy to Web Apps for Containers normally.
## Additional resources
* [Web Apps overview (5-minute overview video)](/azure/app-service/app-service-web-overview)
* [Azure App Service: The Best Place to Host your .NET Apps (55-minute overview video)](https://channel9.msdn.com/events/dotnetConf/2017/T222)
* [Azure Friday: Azure App Service Diagnostic and Troubleshooting Experience (12-minute video)](https://channel9.msdn.com/Shows/Azure-Friday/Azure-App-Service-Diagnostic-and-Troubleshooting-Experience)
* [Azure App Service diagnostics overview](/azure/app-service/app-service-diagnostics)
* <xref:host-and-deploy/web-farm>
Azure App Service on Windows Server uses [Internet Information Services (IIS)](https://www.iis.net/). The following topics pertain to the underlying IIS technology:
* <xref:host-and-deploy/iis/index>
* <xref:fundamentals/servers/aspnet-core-module>
* <xref:host-and-deploy/aspnet-core-module>
* <xref:host-and-deploy/iis/modules>
* [Microsoft TechNet Library: Windows Server](/windows-server/windows-server-versions)