经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Docker » 查看文章
Asp-Net-Core开发笔记:FrameworkDependent搭配docker部署
来源:cnblogs  作者:程序设计实验室  时间:2023/9/10 8:26:14  对本文有异议

前言

之前我写过一篇使用 docker 部署 AspNetCore 应用的文章,这种方式搭配 CICD 非常方便, build 之后 push 到私有的 dockerhub ,在生产服务器上 pull 下来镜像就可以直接运行了。

然而,有时需要一种更传统的部署方式,比如在本地打包可执行文件之后直接放到服务器上执行。

.NetCore 打包可执行文件有两种方式

  • 独立可执行文件 - 不依赖任何运行时环境,直接执行就可以启动
  • 框架依赖 - 需要先安装对应版本的 dotnet-runtime 才可以运行

前者虽然方便,但打包出来比较大,据说在 .net8 版本会有优化,但后面的事后面再说,本文记录第二种方式,框架依赖,搭配 docker 部署,这样就无需在服务器上安装 runtime 了。

(PS:有点Java部署内味了)

这种方式配置完成之后,每次更新只需要重新本地重新 publish 后把可执行文件上传覆盖服务器上的版本即可,非常方便~

不生成 PDB

每次打包会生成一堆 pdb 调试文件,但部署的时候我们不需要这些文件,可以通过配置 .csproj 文件关闭。

  1. <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|AnyCPU'">
  2. <DebugType>none</DebugType>
  3. <DebugSymbols>false</DebugSymbols>
  4. </PropertyGroup>

更好的方式是在解决方案的目录下创建 common.props 文件,把以上配置放在这个文件中,然后每个 .csproj 都引用这个文件,具体路径根据实际情况而定。

  1. <Import Project="../../common.props" />

打包

使用以下命令打包

  1. dotnet publish -f net7.0 -c Release -p:PublishSingleFile=true

打包之后生成一个需要依赖 runtime 运行的可执行文件,接下来准备一下 docker 的配置。

dockerfile

官方的 dockerfile 包含从源码构建到部署的整个流程,我们这里只需要 basefinal ,也就是把可执行文件放进去微软的基础镜像里运行。

  1. FROM mcr.microsoft.com/dotnet/aspnet:7.0 AS base
  2. WORKDIR /app
  3. EXPOSE 80
  4. EXPOSE 443
  5. FROM base AS final
  6. WORKDIR /app
  7. COPY . .
  8. ENTRYPOINT ["./AIHub.Blazor"]

docker-compose

不想每次都打一堆 docker 的命令,或者不想写 bash 脚本的话,docker-compose 是最好的选择,还可以很方便的和其他容器编排使用。

  1. version: '3.6'
  2. services:
  3. web:
  4. image: ${DOCKER_REGISTRY-}web
  5. container_name: aihub
  6. restart: always
  7. environment:
  8. - ASPNETCORE_ENVIRONMENT=Production
  9. - ASPNETCORE_URLS=http://+:80
  10. build:
  11. context: .
  12. volumes:
  13. - .:/app
  14. ports:
  15. - "12001:80"
  16. networks:
  17. - default
  18. - swag
  19. networks:
  20. swag:
  21. name: swag
  22. external: true
  23. default:
  24. name: aihub

补充:

  • ports 节点映射了容器内的 80 端口
  • 我使用了 swag 来提供 web 服务,所以其实不需要使用 ports 映射端口
  • 后续再试用 candy / traefik 来替代 nginx (本项目没有nginx,直接用 kestrel)

启动!

使用命令行启动!

  1. docker compose up

如果没有映射端口的话,还需要接着配置一下反向代理。

swag配置

直接上配置

/path/to/swag/config/nginx/proxy-confs/aihub.subdomain.conf

  1. server {
  2. listen 443 ssl;
  3. listen [::]:443 ssl;
  4. server_name aihub.*;
  5. include /config/nginx/ssl.conf;
  6. client_max_body_size 0;
  7. # enable for ldap auth, fill in ldap details in ldap.conf
  8. #include /config/nginx/ldap.conf;
  9. # enable for Authelia
  10. #include /config/nginx/authelia-server.conf;
  11. location / {
  12. # enable the next two lines for http auth
  13. #auth_basic "Restricted";
  14. #auth_basic_user_file /config/nginx/.htpasswd;
  15. # enable the next two lines for ldap auth
  16. #auth_request /auth;
  17. #error_page 401 =200 /ldaplogin;
  18. # enable for Authelia
  19. #include /config/nginx/authelia-location.conf;
  20. include /config/nginx/proxy.conf;
  21. include /config/nginx/resolver.conf;
  22. set $upstream_app aihub;
  23. set $upstream_port 80;
  24. set $upstream_proto http;
  25. proxy_pass $upstream_proto://$upstream_app:$upstream_port;
  26. proxy_hide_header X-Frame-Options; # Possibly not needed after Portainer 1.20.0
  27. }
  28. }

原文链接:https://www.cnblogs.com/deali/p/17687597.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号