.net webapi Dockerfile 样本
# 请参阅 https://aka.ms/customizecontainer 以了解如何自定义调试容器,以及 Visual Studio 如何使用此 Dockerfile 生成映像以更快地进行调试。
# 在项目目录下编译,因为引用了其它项目,所以指定了上下文目录为解决方案目录 ..
# docker build -t generalapi.apiservice:1.1.0 -f .\Dockerfile ..
# 一共 4 个阶段
# base:基础运行环境,设置工作目录、用户和暴露端口;
# build:构建阶段,恢复 NuGet 包(含自定义源)、编译项目;
# publish:发布阶段,执行 dotnet publish 输出发布文件;
# final:最终镜像,基于 base 阶段,复制发布文件并指定启动命令。
# 此阶段用于在快速模式(默认为调试配置)下从 VS 运行时
FROM mcr.microsoft.com/dotnet/aspnet:9.0 AS base
USER $APP_UID
WORKDIR /app
EXPOSE 8080
EXPOSE 8081
# 此阶段用于生成服务项目
FROM mcr.microsoft.com/dotnet/sdk:9.0 AS build
ARG BUILD_CONFIGURATION=Release
WORKDIR /src
COPY ["GeneralAPI.ApiService/GeneralAPI.ApiService.csproj", "GeneralAPI.ApiService/"]
COPY ["GeneralAPI.ServiceDefaults/GeneralAPI.ServiceDefaults.csproj", "GeneralAPI.ServiceDefaults/"]
# 这里使用了自定义 nuget 源
RUN dotnet restore "./GeneralAPI.ApiService/GeneralAPI.ApiService.csproj" --source https://api.nuget.org/v3/index.json --source https://nuget.x.com
COPY . .
WORKDIR "/src/GeneralAPI.ApiService"
RUN dotnet build "./GeneralAPI.ApiService.csproj" -c $BUILD_CONFIGURATION -o /app/build
# 此阶段用于发布要复制到最终阶段的服务项目
FROM build AS publish
ARG BUILD_CONFIGURATION=Release
RUN dotnet publish "./GeneralAPI.ApiService.csproj" -c $BUILD_CONFIGURATION -o /app/publish /p:UseAppHost=false
# 此阶段在生产中使用,或在常规模式下从 VS 运行时使用(在不使用调试配置时为默认值)
FROM base AS final
LABEL title="通用 webapi"
LABEL description="通用 webapi"
LABEL authors="x"
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "GeneralAPI.ApiService.dll"]
上一篇
下一篇