Docker - не удается запустить ASP.NET Core API с помощью Powershell, но работает с помощью Visual Studio - PullRequest
2 голосов
/ 28 октября 2019

Я пытаюсь запустить основное API ASP.net в контейнере Docker. Запуск из Visual Studio работает отлично, но я не могу получить доступ к API, когда запускаю его с помощью следующей команды powershell:

docker run --name test6 --rm -it -p 9001:80 webapplication6:dev

Он просто возвращает:

root@874b63595efc:/app#

Я ожидаю, что этопокажет мне, что он начал слушать данный порт. Я попытался использовать существующий репозиторий из Docker Hub для проведения теста:

docker run --name aspnetcore_sample --rm -it -p 8000:80 mcr.microsoft.com/dotnet/core/samples:aspnetapp

И он успешно вернул следующее:

info: Microsoft.Hosting.Lifetime[0]
      Now listening on: http://[::]:80
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
      Content root path: /app

Он доступен на моем локальном хосте. Возвращаясь к моему тестовому проекту API, у меня есть следующий текст в моем Dockerfile:

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

FROM mcr.microsoft.com/dotnet/core/sdk:2.1-stretch AS build
WORKDIR /src
COPY ["WebApplication6.csproj", ""]
RUN dotnet restore "./WebApplication6.csproj"
COPY . .
WORKDIR "/src/."
RUN dotnet build "WebApplication6.csproj" -c Release -o /app/build

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

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

Это было автоматически добавлено Visual Studio.

Вот вывод, возвращаемый docker ps

docker ps result

Значение команды для моего тестового приложения - "bash". Нужно ли мне что-то настраивать для запуска контейнера API с использованием Powershell самостоятельно и без использования Visual Studio?

1 Ответ

1 голос
/ 28 октября 2019

Похоже, что механизм докера игнорирует директиву точки входа в вашем Dockerfile, так как вы можете видеть, что команда пуста в вашем работающем контейнере.

Вероятно, вы можете обойти эту проблему, указав директиву CMD в вашем Dockerfile. Попробуйте добавить эту строку в конец вашего Dockerfile и посмотрите, поможет ли это:

CMD ["dotnet", "WebApplication6.dll"]

Кроме того, убедитесь, что ваш образ докера создан с текущей версией Dockerfile, вы можете попробовать использовать эту команду дляубедитесь, что:

docker build -t webapplication6:dev .    
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...