大约一年前,我记得当我们出于开发目的在docker中运行该应用程序时,我们使用dotnet watch run
运行该应用程序。但是在最近的更新中,模板正在创建一个发布版本并运行该版本。我同意这对生产有益。但是为什么开发版本完全消失了?我进行了很多搜索,但找不到发生这种变化的原因。
类似这样的东西:
FROM microsoft/aspnetcore-build:2.0
# Required inside Docker, otherwise file-change events may not trigger
ENV DOTNET_USE_POLLING_FILE_WATCHER 1
# Set a working dir at least 2 deep. The output and intermediate output folders will be /code/obj and /code/bin
WORKDIR /code/app
# By copying these into the image when building it, we don't have to re-run restore everytime we launch a new container
COPY web.csproj .
COPY NuGet.config .
COPY Directory.Build.props .
RUN dotnet restore
# This will build and launch the server in a loop, restarting whenever a *.cs file changes
ENTRYPOINT dotnet watch run --no-restore
现在,每次更改时,我们都需要发布该应用程序以再次使Docker工作。
我看到使用这种新方法在Visual Studio中可以很好地进行调试,但是我对Visual Studio如何附加到容器并进行远程调试感到困惑。令我感到惊讶的是,Visual Studio如何能够调试以发布模式发布的应用程序?
但现在看起来像这样:
FROM microsoft/dotnet:2.2-aspnetcore-runtime AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443
FROM microsoft/dotnet:2.2-sdk AS build
WORKDIR /src
COPY ["MyProject.csproj", "MyProject"]
COPY ["MyProject.Common.csproj", "MyProject.Common"]
RUN dotnet restore "MyProject.csproj"
COPY . .
WORKDIR "/src/MyProject"
RUN dotnet build "MyProject.csproj" -c Release -o /app
FROM build AS publish
RUN dotnet publish "MyProject.csproj" -c Release -o /app
FROM base AS final
WORKDIR /app
COPY --from=publish /app .
ENTRYPOINT ["dotnet", "MyProject.dll"]
答案 0 :(得分:1)
指出明显的情况,但以防万一: dotnet watch等待文件更改,然后重新编译,而无需手动重新启动。
仍然可以使用dotnet watch,但是在复制文件时在容器中没有任何优势。由于文件的复制是在容器构建时进行的,并将它们复制到映像内的源位置,因此即使容器在运行,即使您使用dotnet watch,对代码库的任何更改也不会反映出来。>
如果要使用dotnet watch,请查看将源目录作为卷安装在容器中:)
您可以使用以下内容:
docker run --rm -it -p < port >:< port > -v ~/< sourcedirectory >:/< destination >/ -w /< destination >/aspnetapp mcr.microsoft.com/dotnet/core/sdk:3.0 dotnet watch run
-v标志表示音量,如果不明显的话。如果您想向Dockerfile添加卷,则可以阅读有关Dockerfile & Volumes here的信息。还有dotnet watch here。还有Docker volumes specifically here。最后,在我的历史记录中找到了docker run command的来源。