Please consult documentation for instructions how to compile and publish application.
The rest of this document covers advanced topics only.
For using daily builds, you need to make sure the nuget.config
file for your project contains the following package sources under the <packageSources>
element:
<add key="dotnet9" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet9/nuget/v3/index.json" />
<add key="nuget" value="https://api.nuget.org/v3/index.json" />
If your project has no nuget.config
file, it may be created by running
> dotnet new nugetconfig
from the project's root directory. New package sources must be added after the <clear />
element if you decide to keep it.
Once you have added the package sources, add a reference to the ILCompiler package either by running
> dotnet add package Microsoft.DotNet.ILCompiler -v 9.0.0-*
or by adding the following element to the project file:
<ItemGroup>
<PackageReference Include="Microsoft.DotNet.ILCompiler" Version="9.0.0-*" />
</ItemGroup>
Adding an explicit package reference to Microsoft.DotNet.ILCompiler
will generate warning when publishing and it can run into version errors. When possible, use the default Microsoft.DotNet.ILCompiler
version to publish a native AOT application.
Native AOT toolchain allows targeting ARM64 on an x64 host and vice versa for both Windows and Linux. Cross-OS compilation, such as targeting Linux on a Windows host, is not supported.
The target architecture can be specified using -r
or --arch
options of the dotnet publish
command. For example, the following command produces Windows Arm64 binary on a Windows x64 host machine:
> dotnet publish -r win-arm64
The cross-architecture compilation requires native build tools for the target platform to be installed and configured correctly. On Linux, you may need to follow cross-building instructions to create your own sysroot directory and specify path to it using the SysRoot
property.
See Building native AOT apps in containers for a streamlined path to establishing a Linux cross-compilation environments.
For using daily builds according to the instructions above, in addition to the Microsoft.DotNet.ILCompiler
package reference, also add the runtime.win-x64.Microsoft.DotNet.ILCompiler
package reference to get the x64-hosted compiler:
<PackageReference Include="Microsoft.DotNet.ILCompiler; runtime.win-x64.Microsoft.DotNet.ILCompiler" Version="9.0.0-alpha.1.23456.7" />
Replace 9.0.0-alpha.1.23456.7
with the latest version from the dotnet9 feed.
Note that it is important to use the same version for both packages to avoid potential hard-to-debug issues. After adding the package reference, you may publish for win-arm64 as usual:
> dotnet publish -r win-arm64
Similarly, to target linux-arm64 on a Linux x64 host, in addition to the Microsoft.DotNet.ILCompiler
package reference, also add the runtime.linux-x64.Microsoft.DotNet.ILCompiler
package reference to get the x64-hosted compiler:
<PackageReference Include="Microsoft.DotNet.ILCompiler; runtime.linux-x64.Microsoft.DotNet.ILCompiler" Version="9.0.0-alpha.1.23456.7" />
This feature can statically link libicu libraries (such as libicui18n.a) into your applications at build time. NativeAOT binaries built with this feature can run even when libicu libraries are not installed.
You can use this feature by adding the StaticICULinking
property to your project file as follows:
<PropertyGroup>
<StaticICULinking>true</StaticICULinking>
</PropertyGroup>
This feature is only supported on Linux. This feature is not supported when crosscompiling.
License (Unicode): https://github.com/unicode-org/icu/blob/main/icu4c/LICENSE
Ubuntu
apt install libicu-dev cmake
Alpine
apk add cmake icu-static icu-dev
This feature can statically link OpenSSL libraries (such as libssl.a and libcrypto.a) into your applications at build time. NativeAOT binaries built with this feature can run even when OpenSSL libraries are not installed. WARNING: This is scenario for advanced users, please use with extreme caution. Incorrect usage of this feature, can cause security vulnerabilities in your product
You can use this feature by adding the StaticOpenSslLinking
property to your project file as follows:
<PropertyGroup>
<StaticOpenSslLinking>true</StaticOpenSslLinking>
</PropertyGroup>
This feature is only supported on Linux. This feature is not supported when crosscompiling.
License for OpenSSL v3+ (Apache v2.0): https://github.com/openssl/openssl/blob/master/LICENSE.txt License for OpenSSL releases prior to v3 (dual OpenSSL and SSLeay license): https://www.openssl.org/source/license-openssl-ssleay.txt
Ubuntu
apt install libssl-dev cmake
Alpine
apk add cmake openssl-dev openssl-libs-static
NativeAOT uses native executable ilc
pulled from nuget, which has special requirements. Docs can be found at https://nixos.wiki/wiki/DotNET#NativeAOT