Build and Deploy an ASP .Net Core Web Application as Docker Container using Microsoft Azure – Part 1
This article is the first in the series where we are going to build a simple ASP .Net Core web application, containerize it with Docker and run it on local host. And we will push everything to GitHub for later use.
In the posts to follow, we will setup Microsoft Azure DevOps Build pipeline to automate the process of building and pushing the Docker image to Docker Hub. Next, we will use Azure DevOps Release pipeline to deploy our application on Azure Web App Service as a container.
Do you often ask yourself:
I have built an ASP .Net Core Web Application, now what? How do I take it to next level using tools/platforms like GitHub, Docker, CI/CD and Microsoft Azure with my application?
If YES!! You are at the right place!
Introduction
This article is the first in the series where we are going to:
- build a simple ASP .Net Core web application
- containerize it with Docker and run it on local host
- push everything to GitHub for later use
In later posts, we will setup Microsoft Azure DevOps Build pipeline to automate the process of building and pushing the Docker image to Docker Hub. Next, we will use Azure DevOps Release pipeline to deploy our application on Azure Web App Service as a container.
So, stay with me there is a lot to cover. Let’s get started!
Three parts in series:
- develop an ASP .Net Core web application and containerize it with Docker
- setup Continuous Integration with Microsoft Azure DevOps Pipeline and GitHub
- setup Continuous Deployment pipeline to deploy the application as Docker container on Azure Web App Service
Setup a GitHub Repository
The first step is to setup a repository on GitHub where you are going to put all your code.
This is required because at a later stage you will setup Azure to trigger a build and release, each time you do a push
to your repository.
So login to your GitHub account and create a repository.
Once you have created a repository, it’s time to get it to your local system and start hacking. But before you do that, please make sure that you have Git installed on your system. You can get it from the download page and set it up. It’s easy!
Now, on GitHub, select the repository you have just created. To the right you should see: Clone or download button, click on it and you have the URL to clone your repository.
Open up a terminal or powershell session, navigate to the directory where you want to clone the repository and execute the command:
|
|
With that set, we are ready to start developing our application.
## Create an ASP .Net Core Web Application
In order to create the application you must install .Net Core (version >= 2.0). Go to .Net Core download page and install the SDK compatible with the underlying system.
Now, if you are on Windows open Visual Studio and create a new ASP .Net Core Web Application Project.
New ASP .Net Core Web Application ProjectOn the next page, select the Web Application (Model-View-Controller) template and ensure that: Configure for HTTPS
is unchecked.
Let’s keep it simple. Click OK.
If you are on Linux or Mac OS, open a terminal and navigate to the clone directory. You can create a .Net Core MVC Web App using the following command:
|
|
Once done, you can now use your favorite editor to make required changes.
At this point, I leave it to you, my dear reader, to come up with an idea of your simple application and bring it to life. Or you can follow along as I make changes for my application.
I am building a simple blog that displays a list of latest articles. Please feel free to clone my GitHub repository to get the latest of source code and all the resources used.
Adding Articles Link to Navigation Bar
An ASP .Net Core web application come with a neat predefined template.
To update the navigation bar, open Views/Shared/_Layout.cshtml
.
Under body > nav
section add a link for Articles:
|
|
Now, when we click on the Articles link, an HTTP GET request will be sent to Articles
action in the Home
controller, which is yet to be updated.
Adding required models
Under the Models
directory, add a ArticlesViewModel.cs
, which will have the required model classes:
|
|
Next, let’s add some static data to our blog using the ArticleRepository.cs
:
|
|
Updating the Home Controller
The Home
controller needs to have an action that can handle the requests coming for list of latest articles.
Here is the new controller with Articles
action for GET requests:
|
|
The last thing we need to do is to add a View that will render our data.
So, add an Articles
View under Views/Home/
with the following code to render the latest articles:
|
|
Push your code to GitHub
Once you are done making the code changes, it’s time to push your code on GitHub. Open a terminal and navigate to the project directory.
You can check the status of your local repository using the command
|
|
You should see all the files and directories being added or update. Now, to stage all the changes in your repository run the command:
|
|
Let’s commit the changes with a short meaningful message:
|
|
Finally push all the committed changes to remote branch on GitHub:
|
|
At this point, I am assuming that you have a working application and you are ready to containerize it with Docker.
Dockerfile
According to Docker documentation:
A Dockerfile is a text document that contains all the commands a user could call on the command line to assemble an image. Docker can build images automatically by reading the instructions from a Dockerfile.
Here is the Dockerfile for my application:
|
|
Note that I’m using a multi-stage build to ensure that the final image is as small as possible.
At a high level, a multi-stage build is much like what we generally do while building and publishing our projects. Here is a brief breakdown of the stages:
- STAGE01: at this stage we restore the packages and dependencies our application requires to build. For building the project we need .Net Core SDK, which is our base image.
- STAGE02: once the first stage is successful, we publish our application and store the generated binaries in
/app
directory. - STAGE03: in this stage we use the .Net Core Runtime as our base layer and copy the binaries from
/app
directory, generated in previous stage.
It’s a great way to minimize the size of your Docker images and you can read more about it from the docs.
Because this Dockerfile is specific to my application, you might have to make some changes for it to work.
Running a Container
It’s time to build a Docker image for your application and spin up a container. Open up a terminal and navigate to the directory where the Dockerfile is saved. Now build a Docker image using the command:
|
|
This will build a Docker image and keep it on our local system. To test our image and application we will now run a container using the command:
|
|
The above command creates a container and prints the container ID as output.
You may verify that the container is running using the docker ps
command.
|
|
Now, open a browser and go to the URL http://localhost:5000/. If everything is working fine, you must see your web application’s home page. In my case it looks like this:
Test your application and once you are sure that it’s working commit and push the Dockerfile to your GitHub repository.
Conclusion
In this we have developed a web application using ASP .Net Core and put it on a GitHub repository. We also tested our application by building a Docker image and running a Docker container out of it.
Next step is to setup a Build pipeline on Microsoft Azure DevOps.
This pipeline will connect with our GitHub repository.
We will also set the pipeline to trigger a build each time a push is made to master
branch on the repository.
The pipeline will create a Docker image and push it to Docker Hub.