Run a .NET App
Getting an application running on Fly.io is essentially working out how to package it as a deployable image. Once packaged, it can be deployed to the Fly.io platform.
In this guide we’ll learn how to deploy a .NET application on Fly.io.
Generate the .NET Application
For our example, we will create a simple “hello world” application using the default web template in .NET. We assume that you have already installed .NET.
Once .NET is installed, we can create a new project by running the following command:
dotnet new web --name hellodotnet
The template "ASP.NET Core Empty" was created successfully.
Processing post-creation actions...
Restoring \hellodotnet\hellodotnet.csproj:
Determining projects to restore...
Restored \hellodotnet\hellodotnet.csproj (in 69 ms).
Restore succeeded.
Running the Application
In the new application folder, execute the command dotnet run
to initiate the application:
dotnet run
Building...
Now listening on: http://localhost:5162
Application started. Press Ctrl+C to shut down.
Hosting environment: Development
This command will start the “hellodotnet” application, and you will be able to access it locally using the address provided in the output.
Now, let’s proceed to deploy this application to Fly.
Install Flyctl and Login
We are ready to start working with Fly.io, and that means we need flyctl
, our CLI app for managing apps on Fly.io. If you’ve already installed it, carry on. If not, hop over to our installation guide. Once that’s installed you’ll want to log in to Fly.io.
Launch the app on Fly
Each Fly App needs a fly.toml
file to tell the system how we’d like to deploy it.
That file can be automatically generated with the command flyctl launch
command. This command will also generate a Dockerfile for deployment.
fly launch
Creating app in \fly\guides\hellodotnet
Scanning source code
Detected a .NET app
? Choose an app name (leave blank to generate one): hellodotnet
? Select Organization: demo (demo)
? Select region: ord (Chicago, Illinois (US))
App will use 'ord' region as primary
Created app 'hellodotnet' in organization 'demo'
Admin URL: https://fly.io/apps/hellodotnet
Hostname: hellodotnet.fly.dev
? Would you like to set up a Postgresql database now? No
? Would you like to set up an Upstash Redis database now? No
Wrote config file fly.toml
? Would you like to deploy now? Yes
Deploying hellodotnet
...
That’s it! Run fly apps open
to see your deployed app in action.
Try a few other commands:
fly logs
- Tail your application logsfly status
- App deployment detailsfly deploy
- Deploy the application after making changes
Inside fly.toml
The fly.toml
file now contains a default configuration for deploying your app. In the process of creating that file, flyctl
has also created a Fly-side application slot of the same name, “hellodotnet”. If we look at the fly.toml
configuration file we can see the name in there:
app = "hellodotnet"
primary_region = "ord"
[http_service]
internal_port = 8080
force_https = true
auto_stop_machines = true
auto_start_machines = true
min_machines_running = 0
processes = ["app"]
...
The flyctl
command will always refer to this file in the current directory if it exists, specifically for the app
name/value at the start. That name will be used to identify the application to the Fly.io platform.
The rest of the file contains settings to be applied to the application when it deploys.
Deploying to Fly.io
To deploy changes to your app, just run just run:
fly deploy
This will lookup our fly.toml
file and get the app name hellodotnet
from there.
Then flyctl
will start the process of deploying our application to Fly.io using the Dockerfile. Flyctl will return you to the command line when it’s done.
Viewing the Deployed App
If you want to find out more about the deployment. The command fly status
will give you all the essential details.
fly status
App
Name = hellodotnet
Owner = personal
Hostname = hellodotnet.fly.dev
Image = hellodotnet:deployment-01H4MDR3GVFX20X5DNVZS4BPWK
Platform = machines
Machines
PROCESS ID VERSION REGION STATE CHECKS LAST UPDATED
app 91857500000083 1 ord started 2023-07-06T01:49:28Z
app e2865100000086 1 ord stopped 2023-07-06T01:50:04Z
Connecting to the App
The quickest way to browse your newly deployed application is with the flyctl apps open
command.
flyctl apps open
Opening https://hellodotnet.fly.dev/
Your browser will be sent to the displayed URL.
Bonus Points
If you want to know what IP addresses the app is using, try fly ips list
:
fly ips list
VERSION IP TYPE REGION CREATED AT
v6 2a09:8280:1::69:37fd public global 18m55s ago
v4 66.241.125.223 public (shared)
Arrived at Destination
You have successfully built, deployed, and connected to your first .NET web application on Fly.io.