Visual Studio 2017 Docker-更改多阶段构建的目标

Visual Studio 2017 Docker-更改多阶段构建的目标,docker,visual-studio-2017,.net-core,dockerfile,Docker,Visual Studio 2017,.net Core,Dockerfile,如果我有一个docker文件,它有多个阶段(如base和build),是否有办法更改visual studio在调试容器时使用的docker命令?它似乎使用docker文件中的第一个构建,而不调用后续阶段 这是我的docker文件: FROM microsoft/aspnetcore:2.0.3 AS base WORKDIR /app EXPOSE 80 FROM microsoft/aspnetcore-build:2.0.3 AS build WORKDIR /src COPY *.sl

如果我有一个docker文件,它有多个阶段(如base和build),是否有办法更改visual studio在调试容器时使用的docker命令?它似乎使用docker文件中的第一个构建,而不调用后续阶段

这是我的docker文件:

FROM microsoft/aspnetcore:2.0.3 AS base
WORKDIR /app
EXPOSE 80

FROM microsoft/aspnetcore-build:2.0.3 AS build
WORKDIR /src
COPY *.sln ./
COPY Web/Web.csproj Web/
RUN dotnet restore
COPY . .
WORKDIR /src/Web
RUN dotnet build -c Release -o /app

FROM build AS publish
#RUN npm install
RUN dotnet publish -c Release -o /app

FROM base AS final
WORKDIR /app
COPY --from=publish /app .
# Set the entry point of the application.
ENTRYPOINT ["dotnet", "Web.dll"]
当我点击f5时,它将使用基本映像创建容器,并随后导致错误,因为项目需要安装aspnetcore构建映像的节点;我可以通过将基本映像更改为aspnetcore构建来解决这个问题

但是,有没有一种方法可以告诉VisualStudio中的项目它是一个多阶段构建,需要使用构建


我对docker很陌生,所以可能我遗漏了一些明显的东西。

当您在VS 2017上使用多级Dockerfile时,您可以在调试和发布模式下运行它

在调试模式下,VS将使用“base”目标和标记“DEV”设置docker构建,因此docker将构建一个空映像,正如您已经指出的那样

然后VS将启动图像的容器,因此一旦它运行,就会将代码发布到容器中的当前WORKDIR,启动应用程序并连接到debug

更新


在那周的晚些时候,我发现VS在obj\docker文件夹中生成了一个docker compose文件,负责开发模式下的构建。

我放弃了,将基本映像从aspnetcore更改为aspnetcore构建,如下所示:

FROM microsoft/aspnetcore-build:2.0 AS base
更新: 在vs2019中,现在我们可以设置调试的状态目标:)

根据,当您点击F5时,VisualStudio仅构建第一个图像。但是,我注意到,仅在使用
Debug
配置时才会发生这种情况(如正确所述)

我将所有解决方案配置更改为仅对docker项目(.dcproj)使用
版本
配置。这将生成所有映像并正确执行多阶段生成,而无需将
--target
设置为任何值

编辑


但是,无法从Visual Studio中调试此配置。要允许在容器内进行本地调试,您应该有一个不使用多级生成的单独Dockerfile。

如果我清楚地理解今天所读的内容,Visual Studio采取的调试步骤是(在调试模式下):

  • 在VisualStudio中生成项目文件
  • 基于Dockerfile中的
    base
    构建一个特殊容器(如其他人所述)
  • 启动容器,使用卷映射所有源,执行构建的dll
  • 继续调试
如果这符合我的想法,您可以将
npm install
作为预构建步骤添加到您的csproj文件中,然后您所需的模块应通过卷装载在docker中可用

比如:


要使用docker文件中的构建目标配置,需要添加docker-compose.vs.debug.yml文件。在该文件中,只需指定服务的构建目标即可

例如:

版本:“3.4”
服务:
my.api:
建造:
目标:建立

您知道这是否在任何地方都有官方记录吗?是我还是Visual Studio Docker教程完全不完整?Microsoft的多阶段构建文档令人震惊。再花两分钟,我们就可以节省几天的时间。有些人可能会发现它有有用的信息,但要找到它并不容易,因为它违背了发布和构建时需要不同的DockerRiff的目的,所以我不能说这是一个解决方案,而是一个变通方法。打得好。这个信息很难找到。此外,我将第二个映像命名为“runtime”:
从mcr.microsoft.com/dotnet/aspnet:3.1-alpine设置为runtime
。然后我将csproj配置为在使用调试快捷方式时运行该映像:
runtime
。。。为此,必须将docker compose.dcproj
设置为Visual Studio的启动项目,以设置正确的目标。