ASP.NET Core 应用部署到IIS的核心是IIS通过ANCM反向代理请求至Kestrel服务器。需确保安装Hosting Bundle、正确发布应用、配置IIS站点(应用程序池设为“无托管代码”)、验证web.config生效,最后通过日志排查500.19/502.5错误。

ASP.NET Core 应用部署到 IIS,核心是把它当作一个反向代理后的“独立可执行程序”来运行,IIS 本身不直接托管 .NET Core 代码,而是通过 ASP.NET Core Module(ANCM) 转发请求给后台的 Kestrel 服务器。只要环境配对、发布正确、IIS 设置到位,基本不会出问题。
一、确保服务器环境已就绪
部署前必须确认以下三项都已安装并启用:
- Windows Server 或 Windows 10/11(支持 IIS 10+)
- IIS 已启用:在“启用或关闭 Windows 功能”中勾选“Internet Information Services”及其子项(尤其“Web 管理工具”和“万维网服务”)
- .NET Core 运行时(Runtime)或 托管捆绑包(Hosting Bundle)已安装 —— 推荐装 Hosting Bundle,它自动包含 Runtime + ANCM + IIS 注册逻辑,下载地址:https://www.php.cn/link/ac5a08fd81df9def6dd34354e08bc3bd
二、发布应用(推荐使用“自包含”或“框架依赖”发布)
在项目目录下执行命令行发布(或用 Visual Studio 发布向导),关键点是目标运行时和输出路径:
- 框架依赖发布(轻量,需服务器装 Runtime):
dotnet publish -c Release -r win-x64 --self-contained false -o ./publish - 自包含发布(体积大,无需服务器装 Runtime):
dotnet publish -c Release -r win-x64 --self-contained true -o ./publish - 发布后检查
publish文件夹里是否有yourapp.dll和web.config(若没有 web.config,VS 会自动生成;如用 CLI 发布,可手动添加或用--no-self-contained+--runtime win-x64触发生成)
三、配置 IIS 站点与应用程序池
这是最容易出错的环节,注意细节:
标签: windows app internet 端口 工具 iis ai win microsoft .net
还木有评论哦,快来抢沙发吧~