ASP.NET Core 2 Console.WriteLine Выходные данные не отображаются в журналах Docker - PullRequest
0 голосов
/ 11 апреля 2019

Я пытаюсь добиться того, чтобы выходные данные ILogger.LogError (и других ILogger методов) появлялись в журналах для моего контейнера Docker, но чтобы вывести ILogger из уравнения на данный момент, я Вы только что создали оригинальный API Web App из коробки, используя стандартный шаблон в Visual Studio 2019, выбрав .NET Core 2.2 и отметив флажок, чтобы включить поддержку Docker. Затем я добавил Console.WriteLine("test") в пару мест, которые, я знаю, наверняка попадут при загрузке приложения (и при загрузке страницы). Я ничего не вижу в журналах контейнеров в Kitematic и ничего, когда я запускаю docker logs.

Я довольно неопытен как с Docker, так и с Unix, но, как я понял, Console.WriteLine должен отправлять свой вывод на stdout, который, в свою очередь, должен автоматически записываться в журналы Docker. Есть ли какая-то простая хитрость, чтобы заставить его так себя вести?

Файл 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 ["WebApplication1/WebApplication1.csproj", "WebApplication1/"]
RUN dotnet restore "WebApplication1/WebApplication1.csproj"
COPY . .
WORKDIR "/src/WebApplication1"
RUN dotnet build "WebApplication1.csproj" -c Release -o /app

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

FROM base AS final
WORKDIR /app
COPY --from=publish /app .
ENTRYPOINT ["dotnet", "WebApplication1.dll"]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...