# Zobacz https://aka.ms/customizecontainer, aby dowiedzieć się, jak dostosować kontener debugowania i jak program Visual Studio używa tego pliku Dockerfile do kompilowania obrazów w celu szybszego debugowania. # Ten etap jest używany podczas uruchamiania z programu VS w trybie szybkim (domyślnie dla konfiguracji debugowania) FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base USER app WORKDIR /app EXPOSE 8080 EXPOSE 8081 # Ten etap służy do kompilowania projektu usługi FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build ARG BUILD_CONFIGURATION=Release WORKDIR /src COPY ["MyBookmark.UI.RazorPages/MyBookmark.UI.RazorPages.csproj", "MyBookmark.UI.RazorPages/"] RUN dotnet restore "./MyBookmark.UI.RazorPages/MyBookmark.UI.RazorPages.csproj" COPY . . WORKDIR "/src/MyBookmark.UI.RazorPages" RUN dotnet build "./MyBookmark.UI.RazorPages.csproj" -c $BUILD_CONFIGURATION -o /app/build # Ten etap służy do publikowania projektu usługi do skopiowania do etapu końcowego FROM build AS publish ARG BUILD_CONFIGURATION=Release RUN dotnet publish "./MyBookmark.UI.RazorPages.csproj" -c $BUILD_CONFIGURATION -o /app/publish /p:UseAppHost=false # Ten etap jest używany w środowisku produkcyjnym lub w przypadku uruchamiania z programu VS w trybie regularnym (domyślnie, gdy nie jest używana konfiguracja debugowania) FROM base AS final WORKDIR /app COPY --from=publish /app/publish . ENTRYPOINT ["dotnet", "MyBookmark.UI.RazorPages.dll"]