Read time: 4 minutes
I love building .NET web apps, and the part I enjoy the most is when I get them deployed to the cloud, where anyone can access them from anywhere.
Knowing how to deploy your .NET applications to Azure is a key skill to have since most .NET shops use or are moving to Azure as their cloud provider.
The problem these days is not really to get the app deployed to the cloud, but the fact that there are so many ways to do it, each with its pros and cons, plus a corresponding learning curve.
But today I’ll show you what I think is the best and easiest way to deploy your .NET apps to Azure, using .NET Aspire and the Azure Developer CLI.
Let me show you how to do it in 5 easy steps.
Step 1: Add .NET Aspire to your app
.NET Aspire is an opinionated, cloud-ready stack for building observable, production-ready, cloud-native applications.
Adding .NET Aspire to your application has dozens of benefits, but one of my favorites is that it makes it really easy to deploy your application to Azure via its integration with the Azure Developer CLI.
I wrote an entire article on how to turn a full-stack application into a .NET Aspire application over here, so please check it out before moving on to the next step.
Step 2: Install the Azure Developer CLI
The Azure Developer CLI, also known as azd is an open-source tool that accelerates the time it takes for you to get your application from your box to Azure.
To install the Azure Developer CLI on Windows, run the following command in your terminal:
winget install microsoft.azd
For more options to install it on Windows and other operating systems, check this page.
Step 3: Initialize your app to run on Azure
Run the following command in your terminal to let azd prepare a few deployment artifacts:
azd init
You will get asked a few questions to figure out what kind of application you have, how to deploy it to Azure and to tell if any of your apps should be exposed to the Internet:
After that, you will have a few new files in your repo:
azure.yaml
name: aspiredemo01
services:
app:
language: dotnet
project: .\GameStore.AppHost\GameStore.AppHost.csproj
host: containerapp
Describes the services of your app, such as your .NET Aspire AppHost project, and maps them to Azure resources (Azure Container Apps in this case).
.azure/config.json
{"version":1,"defaultEnvironment":"gamestore04"}
Tells azd what the current active environment is.
.azure/gamestore04/.env
AZURE_ENV_NAME="gamestore04"
Contains environment-specific overrides. In particular, this seems to influence the name of the resource group to create in Azure.
.azure/gamestore04/config.json
{
"services": {
"app": {
"config": {
"exposedServices": [
"frontend"
]
}
}
}
}
Tells azd which services should have a public endpoint in this environment, which is cool since there’s no reason to expose the backend to the Internet.
Step 4: Deploy your .NET application
First things first, login to your Azure account:
azd auth login
Then, kick off the deployment with a single command:
azd up
That will start a new wizard that will ask you key details like your Azure subscription and location to use, as well as any credentials needed, and then it will provision all your Azure resources:
Finally, it will deploy your application as Azure Container Apps resources:
Now, I did face a couple of issues with the deployment, which may be due to the fact I was using preview bits:
-
azd up failed to push the container images to ACR. That’s due to it not granting me the AcrPush role when provisioning the registry. I manually added that permission to my account in the Azure Portal and then ran azd up again. Success!
-
No Allow Blob anonymous access for the Storage Account. My app needs this and there is no way to configure it in my .NET Aspire App. So I had to manually enable this access in the Azure Portal.
Took me 3 minutes to fix both issues and then I was ready to try the published app in my browser.
Step 5: Try the app in Azure
As you can see in the last screenshot, you will get Azure URLs for both your frontend and backend.
In my case, my frontend endpoint was https://frontend.mangobeach-a7b5abba.eastus.azurecontainerapps.io, so if I navigate there I get to my frontend UI:
(those 5 games were not there just after deployment, but I created them afterward for a nice screenshot 😄)
But where are all the Azure resources that got provisioned for that app?
They are all in your Azure subscription, which you can explore in the Azure Portal:
I find it pretty magical how a single command was able to not only provision and interconnect 9 Azure resources, but also turn my frontend and backend into container images, deploy and run them in Azure Container Apps, and even expose the frontend to the Internet.
It would have taken me a few hours to do all that manually, and I would have probably made a few mistakes along the way. But not anymore with .NET Aspire and the Azure Developer CLI.
Mission Accomplished!
Whenever you’re ready, there are 3 ways I can help you:
-
.NET Cloud Developer Bootcamp: Everything you need to build production ready .NET applications for the Azure cloud at scale.
-
Ultimate C# Unit Testing Bundle: A complete beginner to advanced C# unit testing package to write high-quality C# code and ship real-world applications faster and with high confidence.
-
Promote yourself to 20,000+ subscribers by sponsoring this newsletter.