ASP.NET Core怎么部署到IIS ASP.NET Core发布应用程序方法

来源:这里教程网 时间:2026-02-21 17:33:26 作者:

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 站点与应用程序池

这是最容易出错的环节,注意细节:

新建网站时,“物理路径”指向你发布的
publish
文件夹(不是项目根目录,也不是 bin/Debug)
应用程序池 必须设为“无托管代码”(No Managed Code) —— 因为 ASP.NET Core 自己跑 Kestrel,不需要 IIS 加载 .NET Framework 或 .NET Core 托管环境 确保应用程序池“启动模式”为 “始终运行”,“闲置超时”设为 0(避免冷启动延迟) 检查站点绑定是否正确(如 http:80 / https:443),并确认端口未被占用

四、验证 web.config 是否生效

IIS 通过

web.config
调用 ANCM,这个文件不能少,内容应类似:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <location path="." inheritInChildApplications="false">
    <system.webServer>
      <handlers>
        <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
      </handlers>
      <aspNetCore processPath="dotnet" arguments=".\YourApp.dll" stdoutLogEnabled="true" stdoutLogFile=".\logs\stdout" hostingModel="inprocess" />
    </system.webServer>
  </location>
</configuration>

重点字段说明:

processPath
:一般填
dotnet
(要求服务器有全局 dotnet 命令);若用自包含发布,可改为具体路径如
.\YourApp.exe
hostingModel
:推荐
inprocess
(性能更好),也可用
outofprocess
(更稳定,隔离性更强)
stdoutLogEnabled
:上线后建议开启,日志能帮你快速定位启动失败原因(比如端口冲突、缺少依赖、权限不足)

基本上就这些。部署后访问站点,如果看到 500.19 / 502.5 错误,优先查 Windows 事件查看器里的“ASP.NET Core 模块”日志,再配合 stdout 日志定位。不复杂但容易忽略细节。

相关推荐