2016-10-29 01:35:15 +08:00
---
2017-07-01 07:47:15 +08:00
title: Publish an ASP.NET Core app to Azure using Visual Studio
2016-10-29 01:35:15 +08:00
author: rick-anderson
2016-11-18 04:13:02 +08:00
description:
keywords: ASP.NET Core,
2016-10-29 01:35:15 +08:00
ms.author: riande
manager: wpickett
ms.date: 10/14/2016
2017-06-01 05:55:29 +08:00
ms.topic: get-started-article
2016-10-29 01:35:15 +08:00
ms.assetid: 78571e4a-a143-452d-9cf2-0860f85972e6
2016-11-17 08:24:57 +08:00
ms.technology: aspnet
2017-03-03 08:50:36 +08:00
ms.prod: asp.net-core
2016-10-29 01:35:15 +08:00
uid: tutorials/publish-to-azure-webapp-using-vs
---
2017-04-08 04:11:19 +08:00
# Publish an ASP.NET Core web app to Azure App Service using Visual Studio
2016-10-29 01:35:15 +08:00
2016-12-05 13:16:27 +08:00
By [Rick Anderson ](https://twitter.com/RickAndMSFT ) and [Cesar Blum Silveira ](https://github.com/cesarbs )
2016-10-29 01:35:15 +08:00
## Set up the development environment
* Install the latest [Azure SDK for Visual Studio ](https://www.visualstudio.com/features/azure-tools-vs ). The SDK installs Visual Studio if you don't already have it.
> [!NOTE]
> The SDK installation can take more than 30 minutes if your machine doesn't have many of the dependencies.
* Install [.NET Core + Visual Studio tooling ](http://go.microsoft.com/fwlink/?LinkID=798306 )
* Verify your [Azure account ](https://portal.azure.com/ ). You can [open a free Azure account ](https://azure.microsoft.com/pricing/free-trial/ ) or [Activate Visual Studio subscriber benefits ](https://azure.microsoft.com/pricing/member-offers/msdn-benefits-details/ ).
## Create a web app
In the Visual Studio Start Page, tap **New Project...** .
2016-12-23 02:03:29 +08:00
![Start Page ](publish-to-azure-webapp-using-vs/_static/new_project.png )
2016-10-29 01:35:15 +08:00
Alternatively, you can use the menus to create a new project. Tap **File > New > Project...** .
2016-12-23 02:03:29 +08:00
![File menu ](publish-to-azure-webapp-using-vs/_static/alt_new_project.png )
2016-10-29 01:35:15 +08:00
Complete the **New Project** dialog:
* In the left pane, tap **Web**
* In the center pane, tap **ASP.NET Core Web Application (.NET Core)**
* Tap **OK**
2016-12-23 02:03:29 +08:00
![New Project dialog ](publish-to-azure-webapp-using-vs/_static/new_prj.png )
2016-10-29 01:35:15 +08:00
In the **New ASP.NET Core Web Application (.NET Core)** dialog:
* Tap **Web Application**
* Verify **Authentication** is set to **Individual User Accounts**
* Verify **Host in the cloud** is **not** checked
* Tap **OK**
2016-12-23 02:03:29 +08:00
![New ASP.NET Core Web Application (.NET Core) dialog ](publish-to-azure-webapp-using-vs/_static/noath.png )
2016-10-29 01:35:15 +08:00
## Test the app locally
* Press **Ctrl-F5** to run the app locally
* Tap the **About** and **Contact** links. Depending on the size of your device, you might need to tap the navigation icon to show the links
2016-12-23 02:03:29 +08:00
![Web application open in Microsoft Edge on localhost ](publish-to-azure-webapp-using-vs/_static/show.png )
2016-10-29 01:35:15 +08:00
* Tap **Register** and register a new user. You can use a fictitious email address. When you submit, you'll get the following error:
2016-12-23 02:03:29 +08:00
![Internal Server Error: A database operation failed while processing the request. SQL exception: Cannot open the database. Applying existing migrations for Application DB context may resolve this issue. ](publish-to-azure-webapp-using-vs/_static/mig.png )
2016-10-29 01:35:15 +08:00
You can fix the problem in two different ways:
* Tap **Apply Migrations** and, once the page updates, refresh the page; or
2016-12-02 01:15:06 +08:00
* Run the following from a command prompt in the project's directory:
2016-10-29 01:35:15 +08:00
<!-- literal_block {"ids": [], "xml:space": "preserve"} -->
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
dotnet ef database update
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
The app displays the email used to register the new user and a **Log off** link.
2016-12-23 02:03:29 +08:00
![Web application open in Microsoft Edge. The Register link is replaced by the text Hello abc@example.com! ](publish-to-azure-webapp-using-vs/_static/hello.png )
2016-10-29 01:35:15 +08:00
## Deploy the app to Azure
2017-08-14 02:00:48 +08:00
Confirm that the published app for deployment isn't running. Files in the *publish* folder are locked when the app is running. Deployment can't occur because locked files can't be copied.
2016-10-29 01:35:15 +08:00
Right-click on the project in Solution Explorer and select **Publish...** .
2016-12-23 02:03:29 +08:00
![Contextual menu open with Publish link highlighted ](publish-to-azure-webapp-using-vs/_static/pub.png )
2016-10-29 01:35:15 +08:00
In the **Publish** dialog, tap **Microsoft Azure App Service** .
2016-12-23 02:03:29 +08:00
![Publish dialog ](publish-to-azure-webapp-using-vs/_static/maas1.png )
2016-10-29 01:35:15 +08:00
Tap **New...** to create a new resource group. Creating a new resource group will make it easier to delete all the Azure resources you create in this tutorial.
2016-12-23 02:03:29 +08:00
![App Service dialog ](publish-to-azure-webapp-using-vs/_static/newrg1.png )
2016-10-29 01:35:15 +08:00
Create a new resource group and app service plan:
* Tap **New...** for the resource group and enter a name for the new resource group
* Tap **New...** for the app service plan and select a location near you. You can keep the default generated name
* Tap **Explore additional Azure services** to create a new database
2016-12-23 02:03:29 +08:00
![New Resource Group dialog: Hosting panel ](publish-to-azure-webapp-using-vs/_static/cas.png )
2016-10-29 01:35:15 +08:00
* Tap the green ** +** icon to create a new SQL Database
2016-12-23 02:03:29 +08:00
![New Resource Group dialog: Services panel ](publish-to-azure-webapp-using-vs/_static/sql.png )
2016-10-29 01:35:15 +08:00
* Tap **New...** on the **Configure SQL Database** dialog to create a new database server.
2016-12-23 02:03:29 +08:00
![Configure SQL Database dialog ](publish-to-azure-webapp-using-vs/_static/conf.png )
2016-10-29 01:35:15 +08:00
* Enter an administrator user name and password, and then tap **OK** . Don't forget the user name and password you create in this step. You can keep the default **Server Name**
2016-12-23 02:03:29 +08:00
![Configure SQL Server dialog ](publish-to-azure-webapp-using-vs/_static/conf_servername.png )
2016-10-29 01:35:15 +08:00
> [!NOTE]
> "admin" is not allowed as the administrator user name.
* Tap **OK** on the **Configure SQL Database** dialog
2016-12-23 02:03:29 +08:00
![Configure SQL Database dialog ](publish-to-azure-webapp-using-vs/_static/conf_final.png )
2016-10-29 01:35:15 +08:00
* Tap **Create** on the **Create App Service** dialog
2016-12-23 02:03:29 +08:00
![Create App Service dialog ](publish-to-azure-webapp-using-vs/_static/create_as.png )
2016-10-29 01:35:15 +08:00
* Tap **Next** in the **Publish** dialog
2016-12-23 02:03:29 +08:00
![Publish dialog: Connection panel ](publish-to-azure-webapp-using-vs/_static/pubc.png )
2016-10-29 01:35:15 +08:00
* On the **Settings** stage of the **Publish** dialog:
* Expand **Databases** and check **Use this connection string at runtime**
* Expand **Entity Framework Migrations** and check **Apply this migration on publish**
* Tap **Publish** and wait until Visual Studio finishes publishing your app
2016-12-23 02:03:29 +08:00
![Publish dialog: Settings panel ](publish-to-azure-webapp-using-vs/_static/pubs.png )
2016-10-29 01:35:15 +08:00
Visual Studio will publish your app to Azure and launch the cloud app in your browser.
### Test your app in Azure
* Test the **About** and **Contact** links
* Register a new user
2016-12-23 02:03:29 +08:00
![Web application opened in Microsoft Edge on Azure App Service ](publish-to-azure-webapp-using-vs/_static/final.png )
2016-10-29 01:35:15 +08:00
### Update the app
* Edit the `Views/Home/About.cshtml` Razor view file and change its contents. For example:
<!-- literal_block {"ids": [], "linenos": false, "xml:space": "preserve", "language": "html", "highlight_args": {"hl_lines": [7]}} -->
2016-11-18 13:03:07 +08:00
```html
2016-10-29 01:35:15 +08:00
@{
ViewData["Title"] = "About";
}
< h2 > @ViewData["Title"].< / h2 >
< h3 > @ViewData["Message"]< / h3 >
< p > My updated about page.< / p >
2016-11-18 13:03:07 +08:00
```
2016-10-29 01:35:15 +08:00
* Right-click on the project and tap **Publish...** again
2016-12-23 02:03:29 +08:00
![Contextual menu open with Publish link highlighted ](publish-to-azure-webapp-using-vs/_static/pub.png )
2016-10-29 01:35:15 +08:00
* After the app is published, verify the changes you made are available on Azure
### Clean up
When you have finished testing the app, go to the [Azure portal ](https://portal.azure.com/ ) and delete the app.
* Select **Resource groups** , then tap the resource group you created
2016-12-23 02:03:29 +08:00
![Azure Portal: Resource Groups in sidebar menu ](publish-to-azure-webapp-using-vs/_static/portalrg.png )
2016-10-29 01:35:15 +08:00
* In the **Resource group** blade, tap **Delete**
2016-12-23 02:03:29 +08:00
![Azure Portal: Resource Groups blade ](publish-to-azure-webapp-using-vs/_static/rgd.png )
2016-10-29 01:35:15 +08:00
* Enter the name of the resource group and tap **Delete** . Your app and all other resources created in this tutorial are now deleted from Azure
### Next steps
* [Getting started with ASP.NET Core MVC and Visual Studio ](first-mvc-app/start-mvc.md )
2016-11-04 06:32:27 +08:00
* [Introduction to ASP.NET Core ](../index.md )
2016-10-29 01:35:15 +08:00
* [Fundamentals ](../fundamentals/index.md )