ASP.NET Core - Как запустить обновление базы данных в докере? - PullRequest
0 голосов
/ 05 мая 2019

Я использую ASP.NET Core с образом Docker. Одним из образов Docker является PostgreSQL.

Я прочитал это руководство : но здесь файл Docker отличается от того, что было сгенерировано Visual Studio. Я поместил файлigration.sh в раздел сборки файла Docker.

FROM mcr.microsoft.com/dotnet/core/aspnet:2.2-stretch-slim AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443

FROM mcr.microsoft.com/dotnet/core/sdk:2.2-stretch AS build
WORKDIR /src
COPY ["DockerTutorial/DockerTutorial.csproj", "DockerTutorial/"]
COPY ["DockerTutorial/migration.sh", "DockerTutorial/"]
RUN dotnet restore "DockerTutorial/DockerTutorial.csproj"
COPY . .
WORKDIR "/src/DockerTutorial"
RUN chmod +x ./migration.sh
CMD /bin/bash ./migration.sh
RUN dotnet build "DockerTutorial.csproj" -c Release -o /app

FROM build AS publish
RUN dotnet publish "DockerTutorial.csproj" -c Release -o /app

FROM base AS final
WORKDIR /app
COPY --from=publish /app .
ENTRYPOINT ["dotnet", "DockerTutorial.dll"]

Файл оболочки с сайта докера:

#!/bin/bash

set -e
run_cmd="dotnet run --server.urls http://*:80"

until dotnet ef database update; do
>&2 echo "DB is starting up"
sleep 1
done

>&2 echo "DB is up - executing command"
exec $run_cmd
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...