Docker日志中未出现ASP.NET Core 2 Console.WriteLine输出

时间:2019-04-11 09:43:32

标签: c# docker asp.net-core .net-core

我想要实现的是将ILogger.LogError(和其他ILogger方法)的输出显示在我的Docker容器的日志中,但将ILogger移出就目前的方程式而言,我刚刚使用Visual Studio 2019中的标准模板创建了一个通用的即用型Web App API项目,选择了.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"]

0 个答案:

没有答案