HTTP Error 500.0/500.33 - ANCM In-Process Handler Load Failure
ANCM 관련해서,
ASP.NET Core (EXE) 프로세스가 IIS에서 호스팅되는 방법 - ASP.NET Core Module(AspNetCoreModule)
; https://www.sysnet.pe.kr/2/0/11436
.NET Core 2.2/3.0 웹 프로젝트를 IIS에서 호스팅(Inproc, out-of-proc)하는 방법 - AspNetCoreModuleV2 소개
; https://www.sysnet.pe.kr/2/0/12032
3개 정도의 오류 상황을 정리할 수 있습니다. 우선 500.0의 경우 다음과 같이 오류가 발생하는데,
HTTP Error 500.0 - ANCM In-Process Handler Load Failure
Troubleshooting steps:
Check the system event log for error messages
Enable logging the application process' stdout messages
Attach a debugger to the application process and inspect
For more information visit: https://go.microsoft.com/fwlink/?LinkID=2028526
ANCM 모듈을 설치하지 않아서 그런 것이므로 다운로드해,
Current .NET Core Hosting Bundle installer (direct download)
; https://www.microsoft.com/net/permalink/dotnetcore-current-windows-runtime-bundle-installer
설치만 하면 이 문제는 사라집니다.
간혹, 500.0 오류가 발생하면서 이벤트 로그의 메시지가 좀 이상할 수 있습니다.
Log Name: Application
Source: IIS AspNetCore Module V2
Date: 2019-11-25 오후 6:43:02
Event ID: 1031
Task Category: None
Level: Error
Keywords: Classic
User: N/A
Computer: testweb.testad.com
Description:
Application 'D:\TestApp\' failed to start. Exception message:
Process path '.\TestApp.dll' doesn't have '.exe' extension.
이런 경우는, ANCM 모듈명을 dll로 지정했기 때문인데 재미있게도 hostingModel이 "InProcess"여도 processPath 항목을 exe 확장자의 파일로 지정해야 한다는 점입니다.
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<location path="." inheritInChildApplications="false">
<system.webServer>
<handlers>
<remove name="aspNetCore" />
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath=".\TestApp.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" hostingModel="InProcess" />
</system.webServer>
</location>
</configuration>
따라서, 저 DLL 파일명을 .exe로 바꾸면 문제는 해결됩니다.
또는 500.33 오류 코드가 발생할 수 있습니다.
HTTP Error 500.33 - ANCM Request Handler Load Failure
Common solutions to this issue:
Make sure Microsoft.AspNetCore.App is referenced by your application.
Specific error detected by ANCM:
Could not find the assembly 'aspnetcorev2_inprocess.dll' referenced for the in-process application. Please confirm the Microsoft.AspNetCore.Server.IIS or Microsoft.AspNetCore.App is referenced in your application.
Troubleshooting steps:
Check the system event log for error messages
Enable logging the application process' stdout messages
Attach a debugger to the application process and inspect
For more information visit: https://go.microsoft.com/fwlink/?LinkID=2028526
이런 경우라면, 아마도 ASP.NET Core 2.1 이하의 웹 응용 프로그램에 대해 AspNetCoreModuleV2를 사용했기 때문입니다.
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<location path="." inheritInChildApplications="false">
<system.webServer>
<handlers>
<remove name="aspNetCore" />
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath=".\TestApp.exe" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" hostingModel="InProcess" />
</system.webServer>
</location>
</configuration>
AspNetCoreModuleV2 모듈은 .NET Core 2.2부터 지원하기 때문에 해당 프로젝트를 ASP.NET Core 2.2로 마이그레이션해야 합니다. 또는, AspNetCoreModuleV2를 사용하지 말고 "AspNetCoreModule"로 지정해야 하며 당연히 hostingModel도 InProcess는 사용할 수 없습니다.
[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]