paint-brush
Τρόπος αντιμετώπισης σφαλμάτων "hostpolicy.dll" και "singlefilehost.exe" στο .NET 8.0.11με@markpelf
Νέα ιστορία

Τρόπος αντιμετώπισης σφαλμάτων "hostpolicy.dll" και "singlefilehost.exe" στο .NET 8.0.11

με Mark Pelf5m2025/01/03
Read on Terminal Reader

Πολύ μακρύ; Να διαβασω

Μετά από μια αναβάθμιση σε .NET 8.0.11, άρχισα να λαμβάνω σφάλματα και οι εκδόσεις/εφαρμογές απέτυχαν. Έλαβα "hostpolicy.dll...δεν βρέθηκε" και "σφάλμα MSB4018: ... Δεν ήταν δυνατή η εύρεση του ... singlefilehost.exe".
featured image - Τρόπος αντιμετώπισης σφαλμάτων "hostpolicy.dll" και "singlefilehost.exe" στο .NET 8.0.11
Mark Pelf HackerNoon profile picture
0-item

Αλλαγές στο .NET Build Tools Από 8.0.0 σε 8.0.11

Μετά την αναβάθμιση σε.NET 8.0.11, η έκδοση για ορισμένα από τα έργα μου απέτυχε…

1 Περιγραφή προβλήματος

Η δημιουργία ρυθμίσεων έργου λειτούργησε καλά κάπου γύρω από το .NET 8.0.0. Αργότερα, με την αναβάθμιση του χρόνου εκτέλεσης .NET σε νεότερες εκδόσεις του .NET 8.0 και .NET 9.0 και την αναβάθμιση σε Visual Studio, ορισμένα από τα έργα σταμάτησαν να λειτουργούν. Φαίνεται ότι εισήγαγαν σημαντικές αλλαγές στα εργαλεία κατασκευής. Η λογική εξακολουθεί να είναι καλή και οι τύποι κατασκευής είναι οι ίδιοι, απλώς τα εργαλεία κατασκευής άρχισαν να συμπεριφέρονται κάπως διαφορετικά. Απαιτούνται νέες διαμορφώσεις κατασκευής και σενάρια κατασκευής.


Νομίζω ότι μπορώ να εντοπίσω την αλλαγή στη συμπεριφορά κάπου μεταξύ (.NET Framework 8.0.0/.NET SDK 8.0.100) και (.NET Framework 8.0.11/.NET SDK 8.0.404). Όχι όλα, αλλά ορισμένες κατασκευές έργων απέτυχαν.

1.1 Το περιβάλλον

Το τυπικό περιβάλλον στο οποίο ισχύει αυτό το άρθρο είναι το C#/VS2022.

.NET έκδοση 8.0.11 ή μεταγενέστερη

Και δημιουργείτε τύπο έργου SelfContained ή SingleFile

1.2 Εκδήλωση προβλήματος

Λαμβάνετε Σφάλματα/Εξαιρέσεις :

  • Η βιβλιοθήκη 'hostpolicy.dll' που απαιτείται για την εκτέλεση της εφαρμογής δεν βρέθηκε

  • σφάλμα MSB4018: …. Δεν ήταν δυνατή η εύρεση του αρχείου ….. singlefilehost.exe


 +++Error1,When running the application:++++++++++++++++++++ A fatal error was encountered. The library 'hostpolicy.dll' required to execute the application was not found in 'C:\Program Files\dotnet\'. Failed to run as a self-contained app. - The application was run as a self-contained app because 'C:\tmpNetBundle\BundleExample02_NET90\ConsoleApp2C\ SelfContained_SingleFile_win-x64\ConsoleApp2C.runtimeconfig.json' was not found. - If this should be a framework-dependent app, add the 'C:\tmpNetBundle\BundleExample02_NET90\ConsoleApp2C\ SelfContained_SingleFile_win-x64\ConsoleApp2C.runtimeconfig.json' file and specify the appropriate framework. PS C:\tmpNetBundle\BundleExample02_NET90\ConsoleApp2C\ SelfContained_SingleFile_win-x64> +++Error2,During build++++++++++++++++++++ error MSB4018: The "GenerateBundle" task failed unexpectedly. [C:\tmpNetBundle\BundleExample01_NET_8.0.0_SDK_8.0.100\ConsoleApp2\ConsoleApp2.csproj] error MSB4018: System.IO.FileNotFoundException: Could not find file 'C:\tmpNetBundle\BundleExample01_NET_8.0.0_SDK_8.0.100\ConsoleApp2\ obj\Release\net8.0-windows\win-x64\singlefilehost.exe'.


1.3 Αιτία προβλήματος και επίλυση

Φαίνεται ότι η σημαία <PublishSingleFile>true</PublishSingleFile> στο αρχείο του έργου .csproj σταμάτησε να λειτουργεί σε ορισμένες περιπτώσεις. Στη συνέχεια βασιζόμουν σε αυτή τη σημαία στα σενάρια κατασκευής μου. Κανένα πρόβλημα, μπορούμε να το προβλέψουμε αυτό, ακριβώς όταν ξέρουμε τι να περιμένουμε.


Φαίνεται ότι η διαδικασία κατασκευής επικαλέστηκε τη "δημοσίευση dotnet" από το .NET SDK 9.* για έργα που δημιουργούσα για το πλαίσιο .NET 8.*. Έτσι, αποφάσισα να χρησιμοποιήσω το αρχείο global.json για να προσδιορίσω ρητά ποιο SDK θέλω να χρησιμοποιήσω.

2 Δείγματα κωδικών

Αυτές είναι παλιές ρυθμίσεις κατασκευής που λειτουργούσαν στο NET_8.0.0/SDK_8.0.100 αλλά σταμάτησαν να λειτουργούν σε νεότερες εκδόσεις

 // NET_8.0.0/SDK_8.0.100 // NOTE: These project settings all worked well somewhere around .NET 8.0.0. Later, with the upgrade of .NET runtime to later versions of .NET 8.0 and .NET 9.0 and an upgrade to Visual Studio, some of projects stopped working. It looks like they introduced breaking changes in the build tools. Logic is still sound and build types are the same, just the build tools started to behave a bit differently. A new build configurations and build scripts are needed. <!--ConsoleApp2C.csproj +++++++++++++++++++++++++++++++++++++--> <Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <OutputType>Exe</OutputType> <TargetFramework>net8.0-windows</TargetFramework> <ImplicitUsings>enable</ImplicitUsings> <Nullable>enable</Nullable> <PlatformTarget>x64</PlatformTarget> <Platforms>AnyCPU;x64</Platforms> <RuntimeIdentifier>win-x64</RuntimeIdentifier> <DebugType>embedded</DebugType> <PublishSingleFile>true</PublishSingleFile> <PublishTrimmed>true</PublishTrimmed> <IsTrimmable>true</IsTrimmable> <SelfContained>true</SelfContained> <IncludeAllContentForSelfExtract>true</IncludeAllContentForSelfExtract> <EnableCompressionInSingleFile>true</EnableCompressionInSingleFile> </PropertyGroup> <ItemGroup> <ProjectReference Include="..\ClassLibrary1\ClassLibraryA.csproj" /> </ItemGroup> <Target Name="PostBuild" AfterTargets="PostBuildEvent"> <Exec Command="echo +++Post-Build+++++&#xD;&#xA; if $(ConfigurationName) == Debug ( &#xD;&#xA;echo +++++Debug+++++ &#xD;&#xA;) &#xD;&#xA;&#xD;&#xA; if $(ConfigurationName) == Release ( &#xD;&#xA; echo +++++SelfContained_SingleFile_win-x64.cmd+++++ &#xD;&#xA; call SelfContained_SingleFile_win-x64.cmd &#xD;&#xA; echo +++++SelfContained_SingleFile_win-x64_Trimmed.cmd+++++ &#xD;&#xA; call SelfContained_SingleFile_win-x64_Trimmed.cmd &#xD;&#xA;) " /> </Target> </Project> +++++Script: SelfContained_SingleFile_win-x64.cmd dotnet publish ConsoleApp2C.csproj --no-build --runtime win-x64 --configuration Release -p:PublishSingleFile=true -p:SelfContained=true -p:PublishReadyToRun=false -p:PublishTrimmed=false --output ./SelfContained_SingleFile_win-x64 +++++Script: SelfContained_SingleFile_win-x64_Trimmed.cmd dotnet publish ConsoleApp2C.csproj --no-build --runtime win-x64 --configuration Release -p:PublishSingleFile=true -p:SelfContained=true -p:PublishReadyToRun=false -p:PublishTrimmed=true --output ./SelfContained_SingleFile_win-x64_Trimmed


Αυτές είναι νέες ρυθμίσεις έκδοσης που λειτουργούν στο NET_8.0.11/SDK_8.0.404

 // NET_8.0.11/SDK_8.0.404 <!--ConsoleApp2C.csproj +++++++++++++++++++++++++++++++++++++--> <Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <OutputType>Exe</OutputType> <TargetFramework>net8.0-windows</TargetFramework> <ImplicitUsings>enable</ImplicitUsings> <Nullable>enable</Nullable> <PlatformTarget>x64</PlatformTarget> <Platforms>AnyCPU;x64</Platforms> <RuntimeIdentifier>win-x64</RuntimeIdentifier> <DebugType>embedded</DebugType> <PublishSingleFile>true</PublishSingleFile> <PublishTrimmed>true</PublishTrimmed> <IsTrimmable>true</IsTrimmable> <SelfContained>true</SelfContained> <IncludeAllContentForSelfExtract>true</IncludeAllContentForSelfExtract> <EnableCompressionInSingleFile>true</EnableCompressionInSingleFile> </PropertyGroup> <ItemGroup> <PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="9.0.0" /> </ItemGroup> <ItemGroup> <ProjectReference Include="..\ClassLibrary1\ClassLibraryA.csproj" /> </ItemGroup> <Target Name="RunAfterBuild1" AfterTargets="Build"> <Exec Command="call SelfContained_SingleFile_win-x64.cmd" Condition=" '$(BuildingInsideVisualStudio)' == 'true' "/> </Target> <Target Name="RunAfterBuild2" AfterTargets="Build"> <Exec Command="call SelfContained_SingleFile_win-x64_Trimmed.cmd" Condition=" '$(BuildingInsideVisualStudio)' == 'true' "/> </Target> </Project> +++++Script: SelfContained_SingleFile_win-x64.cmd echo .NET SDK version: dotnet --version dotnet publish ConsoleApp2C.csproj --nologo --no-restore --runtime win-x64 --configuration Release -p:PublishSingleFile=true -p:SelfContained=true -p:PublishReadyToRun=false -p:PublishTrimmed=false --output ./SelfContained_SingleFile_win-x64 +++++Script: SelfContained_SingleFile_win-x64_Trimmed.cmd echo .NET SDK version: dotnet --version dotnet publish ConsoleApp2C.csproj --nologo --no-restore --runtime win-x64 --configuration Release -p:PublishSingleFile=true -p:SelfContained=true -p:PublishReadyToRun=false -p:PublishTrimmed=true --output ./SelfContained_SingleFile_win-x64_Trimmed +++++Configfile: global.json { "sdk": { "version": "8.0.404" } }


Αυτές είναι νέες ρυθμίσεις έκδοσης που λειτουργούν στο NET_9.0.0/SDK_9.0.101

 // NET_9.0.0/SDK_9.0.101 <!--ConsoleApp3C.csproj +++++++++++++++++++++++++++++++++++++--> <Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <OutputType>Exe</OutputType> <TargetFramework>net9.0-windows7.0</TargetFramework> <ImplicitUsings>enable</ImplicitUsings> <Nullable>enable</Nullable> <PlatformTarget>x64</PlatformTarget> <Platforms>AnyCPU;x64</Platforms> <RuntimeIdentifier>win-x64</RuntimeIdentifier> <DebugType>embedded</DebugType> <PublishSingleFile>true</PublishSingleFile> <PublishTrimmed>true</PublishTrimmed> <IsTrimmable>true</IsTrimmable> <SelfContained>true</SelfContained> <PublishReadyToRun>true</PublishReadyToRun> <IncludeAllContentForSelfExtract>true</IncludeAllContentForSelfExtract> <EnableCompressionInSingleFile>true</EnableCompressionInSingleFile> </PropertyGroup> <ItemGroup> <PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="9.0.0" /> </ItemGroup> <ItemGroup> <ProjectReference Include="..\ClassLibrary1\ClassLibraryA.csproj" /> </ItemGroup> <Target Name="RunAfterBuild1" AfterTargets="Build"> <Exec Command="call SelfContained_SingleFile_win-x64_ReadyToRun.cmd" Condition=" '$(BuildingInsideVisualStudio)' == 'true' " /> </Target> <Target Name="RunAfterBuild2" AfterTargets="Build"> <Exec Command="call SelfContained_SingleFile_win-x64_Trimmed_ReadyToRun.cmd" Condition=" '$(BuildingInsideVisualStudio)' == 'true' " /> </Target> </Project> +++++Script: SelfContained_SingleFile_win-x64_ReadyToRun.cmd echo .NET SDK version: dotnet --version dotnet publish ConsoleApp3C.csproj --nologo --no-restore --runtime win-x64 --configuration Release -p:PublishSingleFile=true -p:SelfContained=true -p:PublishTrimmed=false -p:PublishReadyToRun=true --output ./SelfContained_SingleFile_win-x64_ReadyToRun +++++Script: SelfContained_SingleFile_win-x64_Trimmed_ReadyToRun.cmd echo .NET SDK version: dotnet --version dotnet publish ConsoleApp3C.csproj --nologo --no-restore --runtime win-x64 --configuration Release -p:PublishSingleFile=true -p:SelfContained=true -p:PublishReadyToRun=true -p:PublishTrimmed=true --output ./SelfContained_SingleFile_win-x64_Trimmed_ReadyToRun +++++Configfile: global.json { "sdk": { "version": "9.0.101" } }