The official installer for .NET 7.0/8.0 at this moment only properly installs ASP.NET Core module ARM64 bits on the machine, so that only pure ARM64 ASP.NET Core web apps can run on IIS. The application pool simply crashes when you try to host x86 or x64 web apps.
Note that .NET 6.0 web apps can only run in x64/x86 modes on IIS/Windows 11 ARM64. There wasn't no Windows ARM64 support in 6.0 release.
The changes made by this repo have been delivered to Microsoft ASP.NET Core team in dotnet/aspnetcore/issues/47115. However, they decided that no immediate action to take. You can vote it up there and describe why the patch is important and should be included in the official installer. That might help prioritize the issue on their roadmap.
I also wrote about my investigation on this topic in details and hope you find the technical details useful.
Perform the following steps to prepare the environment on your development machine,
-
Download the original 64 bit installer from Microsoft.
-
Download WiX Toolset if it isn't installed to
%ProgramFilesX86%\WiX Toolset v3.11\bin\
. -
Extract all contents from original Microsoft installer using
dark.exe
withdark.exe dotnet-hosting-7.0.4-win.exe -x .\msi
At this stage, all useful bits can be found in \msi\AttachedContainer
folder, such as AspNetCoreModuleV2_*.msi
. This folder provides all files are later used for patching.
Note that here we use .NET 7.0.4 as an example. The same approach should apply to other versions (including .NET 8 Preview) till Microsoft officially ships the necessary changes in future releases.
- Execute the official installer to install ARM64 bits to IIS.
- Clone this repo to your local disk.
- Execute
patch.ps1 -msiFolder <folder>
(this points to theAttachedContainer
folder in earlier steps) as administrator so that it extracts the necessary files from those MSI packages and install to the desired places.Note that this install script also installs a few helper files compiled by me. They are ARM64X pure forwarders required for ARM64/x64 side by side execution. The source code and build script are in
src
folder.
- Execute
restore.ps1
as administrator.
You should restore to default before upgrading the hosting bundle to a newer version.