部署.NET6.0 Web API项目到Docker

介绍

使用VS2022创建一个.NET6Web API项目,将其打包,并部署到Linux服务器上的Docker中。

Linux和Docker环境已经备好,本文不再赘述,主要记录一下.NET6项目的创建和部署流程。

其中,部署方式不止一种,本文给出常见的一种方式。

代码及配置文件参考:https://gitee.com/redcod/net6-webapi-deploy-demo

创建.NET WebAPI项目

  1. 选择ASP.NET Core Web API项目:
    在这里插入图片描述

  2. 项目名称叫做web-dotnet
    在这里插入图片描述

  3. 项目参数
    在这里插入图片描述

  4. 启动项目

在这里插入图片描述

  1. (开启了OpenAPI支持)启动后会自动打开Swagger页面,从中找到接口地址

在这里插入图片描述

  1. 在浏览器中访问该地址

在这里插入图片描述

项目打包

  1. 在Program.cs中配置一下端口(此示例使用端口9530),配置端口的方式不止一种,只试验了这一种:
builder.WebHost.UseUrls("http://*:9530");

在这里插入图片描述

  1. 右击项目,点击【发布】
    在这里插入图片描述

  2. 选择【文件夹】的方式
    在这里插入图片描述

  3. 使用默认的发布输出路径,也可以更改
    在这里插入图片描述

  4. 点击【发布】,可以在【更多操作】中配置其他发布参数,本文采用默认参数。
    在这里插入图片描述

  5. 发布成功,点击【目标位置】则打开发布文件夹
    在这里插入图片描述

  6. 发布结果都在public文件夹内
    在这里插入图片描述

  7. 将public文件夹压缩为zip(方便上传到Linux后再解压,也可以直接上传public文件夹):
    在这里插入图片描述

项目部署

文件准备

可以使用MobaXterm工具远程连接Linux服务器。

在Linux服务器某个文件夹内准备好以下五个内容:
在这里插入图片描述

  1. public文件夹(打包结果)
  2. Dockerfile配置文件(构建docker镜像时的参数)
# 此阶段用于在快速模式(默认为调试配置)下从 VS 运行时
FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
WORKDIR /app
EXPOSE 9530
COPY ./publish ./

ENTRYPOINT ["dotnet", "web-dotnet.dll"]
  1. build.sh脚本(生成docker镜像的脚本)
    后面部署时直接运行脚本,不必输入很长的命令。
    脚本内容(需根据项目名称灵活调整):
docker  build -t web-dotnet:prod-1.0 -f Dockerfile .
  1. docker-compose.yml配置文件(用于配置镜像运行环境,即容器环境)
version: "3"
services:
  web-dotnet:
    container_name: web-dotnet
    image: web-dotnet:prod-1.0
    restart: always
    networks:
     - docker_net
    ports:
     - 9530:9530
networks:
  docker_net:
    external:
      name: docker_net

  1. deploy.sh脚本(根据镜像创建容器并运行)
docker-compose -f docker-compose.yml up -d

部署命令

上面文件准备好后,依次运行build.sh和deploy.sh两个脚本即可。

效果图:

在这里插入图片描述
后续更新项目时,只需要先更新public文件夹,再依次运行这两个脚本,最后再删除旧版本的镜像。

可能的问题与解决

初次运行脚本时可能会出现无权限的提示:

在这里插入图片描述
则可以参考:https://blog.csdn.net/j123kaishichufa/article/details/9193475
也就是执行:

chmod 777 build.sh
chmod 777 deploy.sh

在这里插入图片描述

<think>好的,用户想在Windows Server上使用Docker部署.NET Core Web API应用程序。我需要一步步指导他们完成这个过程。首先,我得确认用户的环境是否符合要求,比如安装Docker.NET SDK。然后,创建项目部分,用户可能需要知道如何用CLI生成项目结构。接下来是添加Dockerfile,这部分要详细说明如何编写和配置,比如基础镜像、构建命令等。构建和运行容器时,可能需要解释常用的Docker命令,比如docker build和docker run。另外,用户可能还需要了解如何配置数据库连接,比如使用环境变量或者在容器中连接其他服务。最后,部署到Windows Server时,要提到可能的网络配置和持久化存储的问题。还要注意引用微软的指南,确保信息的准确性。同时,生成相关问题时要覆盖常见的后续步骤,比如调试、多容器部署和性能优化。</think>在Windows Server上通过Docker容器化部署.NET Core Web API的步骤如下: ### 一、环境准备 1. 安装Docker Desktop for Windows(需开启Hyper-V虚拟化) 2. 确认安装.NET 6.0 SDK(推荐最新LTS版本) 3. 验证环境: ```powershell docker --version dotnet --version ``` ### 二、创建.NET Core WebAPI项目 ```powershell dotnet new webapi -n YourProject.API cd YourProject.API ``` ### 三、添加Docker支持 1.项目根目录创建`Dockerfile`: ```dockerfile # 构建阶段 FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build WORKDIR /src COPY . . RUN dotnet restore RUN dotnet publish -c Release -o /app # 运行阶段 FROM mcr.microsoft.com/dotnet/aspnet:6.0 WORKDIR /app COPY --from=build /app . ENV ASPNETCORE_URLS=http://+:5000 EXPOSE 5000 ENTRYPOINT ["dotnet", "YourProject.API.dll"] ``` 2. 创建`.dockerignore`文件: ``` **/bin/ **/obj/ Dockerfile .dockerignore ``` ### 四、构建与运行容器 ```powershell # 构建镜像 docker build -t yourproject-api . # 运行容器(开发模式) docker run -d -p 5000:5000 --name api-container yourproject-api # 生产环境推荐添加重启策略 docker run -d -p 5000:5000 --restart=always --name api-prod yourproject-api ``` ### 五、数据库配置(以SQL Server为例) ```powershell # 启动SQL Server容器 docker run -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=YourStrong@Passw0rd" -p 1433:1433 --name sql-server -d mcr.microsoft.com/mssql/server:2019-latest # 修改appsettings.json连接字符串 "ConnectionStrings": { "DefaultConnection": "Server=sql-server;Database=YourDB;User=sa;Password=YourStrong@Passw0rd;" } ``` ### 六、部署到Windows Server 1. 导出镜像文件: ```powershell docker save -o yourproject-api.tar yourproject-api ``` 2. 上传到服务器后加载镜像: ```powershell docker load -i yourproject-api.tar ``` 3. 使用docker-compose部署(推荐): 创建`docker-compose.yml`: ```yaml version: '3.8' services: webapi: image: yourproject-api ports: - "5000:5000" depends_on: - sql-server sql-server: image: mcr.microsoft.com/mssql/server:2019-latest environment: SA_PASSWORD: "YourStrong@Passw0rd" ACCEPT_EULA: "Y" ``` ### 七、验证部署 访问 `http://localhost:5000/swagger` 查看API文档[^1]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值