We are going to host our container in an Azure App Service Plan.
-
Navigate to the Azure Portal, and go to the Azure resource group containing your Container Registry.
-
Click on Create and search for Web App for Containers. Click Create.
-
On the next screen, leave the subscription and resource on default (if they aren't selected, choose the subscription and resource group you have been using in this lab). Leave everything else on default, apart from:
- Name: Choose a unique name for your web app - I suggest using the same name as your resource group to make sure it is unique - e.g. GitHubWorkshop12345678
- Region: Choose the same region as you used earlier
-
Click Docker (note: you can ignore the Deployment tab)
- Change Image Source to Azure Container Registry and select your registry from the dropdown.
- Select the image eshop from the dropdown.
-
Click Review + create. Once validated, click create and wait for your web app to deploy.
There is one configuration change we need to make.
-
Navigate to your newly created web app, and click on Configuration.
-
Add a new Application Setting called ASPNETCORE_ENVIRONMENT and give it a value of DEVELOPMENT. Click OK and then Save.
You can now browse to your website by clicking on Browse on the overview page - you should see the front end for our eShop:
So what have we actually got working so far?
We have a pipeline which takes triggers on changes to the main branch. It builds and tests the .NET Core application to make sure we haven't broken anything. The workflow then builds a Docker image using the Dockerfile we specified, and pushes that image into our private container registry hosted in Azure.
In the next lab, we will:
- Update the workflow to deploy new container images to the web app
- Create environments to reflect staging and production, with approvals