6.6 KiB
title | author | description | monikerRange | ms.topic | content_well_notification | ms.author | ms.custom | ms.date | uid | ai-usage |
---|---|---|---|---|---|---|---|---|---|---|
Tutorial: Publish an ASP.NET Core app using Native AOT | mitchdenny | Learn about how to publish an ASP.NET Core app using Native AOT. | >= aspnetcore-8.0 | tutorial | AI-contribution | midenn | mvc | 08/10/2023 | fundamentals/native-aot-tutorial | ai-assisted |
Tutorial: Publish an ASP.NET Core app using Native AOT
ASP.NET Core 8.0 introduces support for .NET native ahead-of-time (AOT).
[!NOTE]
- The Native AOT feature is currently in preview.
- In .NET 8, not all ASP.NET Core features are compatible with Native AOT.
- Tabs are provided for the .NET CLI and Visual Studio instructions:
- Visual Studio is a prerequisite even if the CLI tab is selected.
- The CLI must be used to publish even if the Visual Studio tab is selected.
Prerequisites
.NET CLI
-
On Linux, see Prerequisites for Native AOT deployment.
-
Visual Studio 2022 Preview with the Desktop development with C++ workload installed.
[!NOTE] Visual Studio 2022 Preview is required because Native AOT requires link.exe and the Visual C++ static runtime libraries. There are no plans to support Native AOT without Visual Studio.
Visual Studio
-
Visual Studio 2022 Preview with the following workloads installed:
- ASP.NET and web development
- Desktop development with C++
Create a web app with Native AOT
Create an ASP.NET Core API app that is configured to work with Native AOT:
.NET CLI
Run the following commands:
dotnet new webapiaot -o MyFirstAotWebApi && cd MyFirstAotWebApi
Output similar to the following example is displayed:
The template "ASP.NET Core Web API (Native AOT)" was created successfully.
Processing post-creation actions...
Restoring C:\Code\Demos\MyFirstAotWebApi\MyFirstAotWebApi.csproj:
Determining projects to restore...
Restored C:\Code\Demos\MyFirstAotWebApi\MyFirstAotWebApi.csproj (in 302 ms).
Restore succeeded.
Visual Studio
- Create a new
ASP.NET Core Web API (Native AOT)
project. - Name the project MyFirstAotWebApi.
- Select Create.
Publish the Native AOT app
Verify the app can be published using Native AOT:
.NET CLI
dotnet publish
Visual Studio
Visual studio doesn't support publishing an AOT app. Use the CLI command:
dotnet publish
The dotnet publish
command:
- Compiles the source files.
- Generates source code files that are compiled.
- Passes generated assemblies to a native IL compiler. The IL compiler produces the native executable. The native executable contains the native machine code.
Output similar to the following example is displayed:
MSBuild version 17.<version> for .NET
Determining projects to restore...
Restored C:\Code\Demos\MyFirstAotWebApi\MyFirstAotWebApi.csproj (in 241 ms).
C:\Code\dotnet\aspnetcore\.dotnet\sdk\8.0.<version>\Sdks\Microsoft.NET.Sdk\targets\Microsoft.NET.RuntimeIde
ntifierInference.targets(287,5): message NETSDK1057: You are using a preview version of .NET. See: https://aka.ms/dotne
t-support-policy [C:\Code\Demos\MyFirstAotWebApi\MyFirstAotWebApi.csproj]
MyFirstAotWebApi -> C:\Code\Demos\MyFirstAotWebApi\bin\Release\net8.0\win-x64\MyFirstAotWebApi.dll
Generating native code
MyFirstAotWebApi -> C:\Code\Demos\MyFirstAotWebApi\bin\Release\net8.0\win-x64\publish\
The output may differ from the preceding example depending on the version of .NET 8 used, directory used, and other factors.
Review the contents of the output directory:
dir bin\Release\net8.0\win-x64\publish
Output similar to the following example is displayed:
Directory: C:\Code\Demos\MyFirstAotWebApi\bin\Release\net8.0\win-x64\publish
Mode LastWriteTime Length Name
---- ------------- ------ ----
-a--- 30/03/2023 1:41 PM 9480704 MyFirstAotWebApi.exe
-a--- 30/03/2023 1:41 PM 43044864 MyFirstAotWebApi.pdb
The executable is self-contained and doesn't require a .NET runtime to run. When launched, it behaves the same as the app run in the development environment. Run the AOT app:
.\bin\Release\net8.0\win-x64\publish\MyFirstAotWebApi.exe
Output similar to the following example is displayed:
info: Microsoft.Hosting.Lifetime[14]
Now listening on: http://localhost:5000
info: Microsoft.Hosting.Lifetime[0]
Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
Content root path: C:\Code\Demos\MyFirstAotWebApi
See also
- xref:fundamentals/native-aot
- Native AOT deployment
- Using the configuration binder source generator
- The minimal API AOT compilation template
- Comparing
WebApplication.CreateBuilder
toCreateSlimBuilder
- Exploring the new minimal API source generator
- Replacing method calls with Interceptors
- Configuration-binding source generator