0

0

C# Docker容器化方法 C#如何为ASP.NET Core应用创建Dockerfile

畫卷琴夢

畫卷琴夢

发布时间:2026-01-25 10:39:52

|

994人浏览过

|

来源于php中文网

原创

必须启用Release配置发布、匹配SDK与Runtime镜像版本、ENTRYPOINT指向发布后的.dll文件、配置.dockerignore文件。否则会导致镜像臃肿、启动失败或安全风险。

c# docker容器化方法 c#如何为asp.net core应用创建dockerfile

ASP.NET Core项目必须启用发布配置才能正确构建镜像

直接在项目根目录运行 dotnet publish 时若未指定配置,会默认使用 Debug,导致生成的输出包含调试符号、未裁剪的依赖,镜像体积大且存在安全风险。Docker 构建过程应严格使用 Release 配置。

  • 确保 .csproj 中未硬编码 DebugType 或覆盖 Optimize
  • Dockerfile 中的 dotnet publish 命令必须显式加 -c Release
  • 若项目引用了 Microsoft.AspNetCore.App 共享框架,发布时需用 --self-contained false(默认行为),否则会打包整个运行时,镜像膨胀数倍。

Dockerfile 多阶段构建必须匹配 SDK 与 Runtime 镜像版本

常见错误是 SDK 镜像用 7.0,而 runtime 镜像写成 6.0,导致 Could not load file or assembly 或启动失败。版本不一致还会引发 TLS、JSON 序列化等运行时行为差异。

  • 查看项目 TargetFramework(如 net7.0),以此为准选择镜像标签;
  • SDK 阶段用 mcr.microsoft.com/dotnet/sdk:7.0,runtime 阶段用 mcr.microsoft.com/dotnet/aspnet:7.0(不是 runtime,ASP.NET Core 应用需 aspnet 镜像,它内置了 IIS 模块和 HTTPS 支持);
  • 避免使用 latest 标签——它可能跨主版本,破坏确定性。

ENTRYPOINT 必须指向已发布的可执行文件,而非项目文件

写成 ENTRYPOINT ["dotnet", "MyApp.csproj"] 是错的:容器内没有 SDK,且 .csproj 不是可执行体。正确路径是发布后生成的 .dll 文件,且该文件名与项目名一致(除非显式设置了 AssemblyName)。

刺鸟创客
刺鸟创客

一款专业高效稳定的AI内容创作平台

下载
  • 发布命令输出目录(如 ./bin/Release/net7.0/publish/)中的 MyApp.dll 才是入口;
  • ENTRYPOINT ["dotnet", "MyApp.dll"] 是标准写法;
  • 若应用监听非 http://+:80 地址,需通过 ASPNETCORE_URLS 环境变量覆盖,例如 ENV ASPNETCORE_URLS=http://+:5000
  • 不要在 Dockerfile 中用 CMD 替代 ENTRYPOINT —— 后者更符合 .NET 容器最佳实践,也便于 docker run 传参扩展。

构建时忽略 .git、obj、bin 目录能显著提速并防止敏感泄露

Docker 构建上下文默认上传当前目录所有文件。若未排除 obj/bin/,不仅拖慢构建,还可能把本地 NuGet 缓存路径、用户密钥等意外打进镜像层。

  • 在项目根目录创建 .dockerignore,内容包括:
    .git
    bin/
    obj/
    .vs/
    .user
    .env
  • 不要在 Dockerfile 中用 RUN rm -rf /app/obj 补救——这些文件早已存在于上层镜像中,无法真正删除;
  • 若项目含 appsettings.Development.json,也建议加入 .dockerignore,生产镜像应只保留 appsettings.json 和环境变量驱动的配置。
实际构建命令就是 docker build -t myapp .,但镜像是否精简、能否稳定运行,全取决于上面四点是否被严格执行。最容易被跳过的其实是 .dockerignore 和 runtime 镜像版本对齐——这两个地方出问题,往往表现为容器启动后立即退出,日志里只有 exit code 139 或空白输出。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

417

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

703

2023.07.05

git和svn的区别
git和svn的区别

git和svn的区别:1、定义不同;2、模型类型不同;3、存储单元不同;4、是否拥有全局版本号;5、内容完整性不同;6、版本库不同;7、克隆目录速度不同;8、分支不同。php中文网为大家带来了git和svn的相关知识、以及相关文章等内容。

551

2023.07.06

git撤销提交的commit
git撤销提交的commit

Git是一个强大的版本控制系统,它提供了很多功能帮助开发人员有效地管理和控制代码的变更,本专题为大家提供git 撤销提交的commit相关的各种文章内容,供大家免费下载体验。

266

2023.07.24

git提交错误怎么撤回
git提交错误怎么撤回

git提交错误撤回的方法:git reset head^:撤回最后一次提交,恢复到提交前状态。git revert head:创建新提交,内容与之前提交相反。git reset :使用提交的 sha-1 哈希撤回指定提交。交互式舞台区:标记要撤回的特定更改,然后提交,排除已撤回更改。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

550

2024.04.09

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号