.NET Core 3.0 和 IIS:HTTP 错误 500.30 - ANCM 进程内启动失败:无法加载 coreclr

问题描述 投票:0回答:5

我的应用程序在我的开发工作站上的 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 个字符。如果您想查看特定内容,请告诉我,我会尽力提供相关片段。感谢您提供的任何建议!

.net-core iis-8 .net-core-3.0
5个回答
22
投票

我更改了 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">

还有宾果游戏!应用程序按预期运行。

谁能解释一下为什么?


7
投票

我也遇到过同样的问题,在花了一些时间寻找根本原因和可能的解决方案后,我了解到当同一台计算机上存在有许多应用程序池时,就会发生这种情况,这就是我的情况。

Microsoft 建议“错开多个应用程序的启动过程”。另一个解决方案是增加启动限制 关于hostProcess从

Inbound

更改为Outbound,这可能有效,但不会使用IS HTTP服务器,而是使用Kestrel Web服务器来处理请求。 在这里您可以找到更多信息:

Azure 应用服务和 IIS 上的 ASP.NET Core 故障排除 |微软文档

asp.net core中Inprocess和OutOfprocess服务有什么区别|教程帮手


4
投票


2
投票

Image of project setting to change


0
投票

© www.soinside.com 2019 - 2024. All rights reserved.