Я пытаюсь добиться того, чтобы выходные данные 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"]