-
Notifications
You must be signed in to change notification settings - Fork 568
Deploy Windows Container to Azure App Service
Azure Web App for Containers provides a very simple way to deploy containerized applications on Windows (or Linux). This fully-managed platform eases infrastructure maintenance and supports built-in auto scaling and load balancing.
This walkthrough shows you how to create a new Azure Web App for Containers and how to deploy eShopModernizing apps into this new app service.
First, you'll need an Azure account. Create a free account now if necessary. Next, create an Azure App Services Web App. In the Azure Portal, add a new "App Services" resource (you can search for this term in the add dialog). Fill out the form as shown here:
- Choose your subscription and a resource group (create a new one if desired)
- Give the app a unique name (with an available URL)
- Choose 'Docker Image' for the Publish option
- Make sure to choose Windows for the Operating System
- Choose an App Service Plan that will accommodate your app (it should be at least the PC3 size)
Note: In order to use a Windows Container for an eShopModernizing app you'll need to select at least a PC3 option. This app includes the SQL Server container image, which alone is about 15 GB, and also includes the ASP.NET container image, which is about 14 GB. The PC2 option has a maximum total size of 19 GB, and will result in an error if it is used.
Click 'Next: Docker >`.
Configure Docker as follows:
- Image Source: Docker Hub
- Access Type: Public
- Image and tag: eshop/modernizedmvc:master
Click 'Review and Create'.
Review the options, which should be similar to those shown in the image above.
Click 'Create'. The deployment will commence, and in a few moments you should see a confirmation that the container is deployed and starting up.
Click 'Go to resource' and you'll be taken to the resource's overview in the Azure Portal.
Click 'Browse' to navigate to the site. It may still be starting, in which case you'll see a screen like this one:
To review the app's configuration and its current status, click on Container settings
in the Azure Portal for the app service:
Refresh and scroll down through the logs to see the progress as the container is downloaded and configured. Also, turn on Continuous Deployment if you'd like to have the container automatically updated any time a new version is published to the registry. Here you can see CD is enabled, and Azure is successfully swapping the new container with the old one, as noted in the logs:
Once the app is up and running, you should see something like this:
The instructions for publishing the modernized Web Forms and WCF applications are similar to those shown above for the ModernizedMVC app. The most important difference is obviously the name of the image to use. When you configure Docker's Image and tag setting, use eshop/modernizedwebforms:master
for Web Forms and eshop/wcfservice:master
for the WCF service (that the Windows Forms application communicates with over HTTP).
Once deployed, the modernized Web Forms app should look like this:
and the WCF Service should look like this (navigate to /CatalogService.svc
):
- Home
- Release notes
- e-books
-
MVC & Web Forms Samples
- Tour of the "legacy" ASP.NET web apps to modernize
- How to containerize the .NET Framework web apps with Windows Containers and Docker
- Publishing your Windows Container images into a Docker Registry
- Deploying the Apps to Azure Web Apps for Containers
- Deploying the Apps to ACI (Azure Container Instances)
- Deploying your Windows Containers based app into Azure VMs (Including CI CD)
- Deploying into local Kubernetes in Windows 10 and Docker for Windows development environment
- How to deploy your Windows Containers based apps into Kubernetes in Azure Container Service (Including CI CD)
- How to add authentication authorization with Azure Active Directory
- How to migrate the SQL database to Azure with the Azure Database Migration Service
- Using Application Insights in eShopOnContainers
- N-Tier sample: WinForms app and WFC service
- ASP.NET to Azure App Service Migration Workshop