我的应用程序在我的开发工作站上的 IIS Express 中运行良好,但我在将其部署到 IIS 时遇到问题。当我浏览到该应用程序时,我收到以下错误:
HTTP 错误 500.30 - ANCM 进程内启动失败
Windows 事件日志中没有太多内容:
Application '/LM/W3SVC/2/ROOT' with physical root 'c:\inetpub\cashflow\' failed to load coreclr. Exception message:
Error occured when initializing inprocess application, Return code: 0x80008083
据我所知,从命令行调用时应用程序运行良好:
这是我在失败的请求跟踪中看到的内容:(我有点困惑为什么文件被标识为 F:...Tehre 在这台机器上没有 F:\ 驱动器!)
抱歉,我无法提供完整的跟踪 XML,因为它超过 100,000 个字符。如果您想查看特定内容,请告诉我,我会尽力提供相关片段。感谢您提供的任何建议!
我更改了 Web.config 中的规范以在进程外运行。最初的 InProcess 规范如下:
<aspNetCore processPath="dotnet" arguments=".\Cashflow.dll" stdoutLogEnabled="false" hostingModel="InProcess" stdoutLogFile=".\logs\stdout">
我将其更改为 OutOfProcess:
<aspNetCore processPath="dotnet" arguments=".\Cashflow.dll" stdoutLogEnabled="false" hostingModel="OutOfProcess" stdoutLogFile=".\logs\stdout">
还有宾果游戏!应用程序按预期运行。
谁能解释一下为什么?
我也遇到过同样的问题,在花了一些时间寻找根本原因和可能的解决方案后,我了解到当同一台计算机上存在有许多应用程序池时,就会发生这种情况,这就是我的情况。
Microsoft 建议“错开多个应用程序的启动过程”。另一个解决方案是增加启动限制。 关于hostProcess从
Inbound更改为Outbound,这可能有效,但不会使用IS HTTP服务器,而是使用Kestrel Web服务器来处理请求。 在这里您可以找到更多信息:
Azure 应用服务和 IIS 上的 ASP.NET Core 故障排除 |微软文档asp.net core中Inprocess和OutOfprocess服务有什么区别|教程帮手