1

我将我的应用程序设置为使用 Serilog 作为日志记录机制。事实上,我确实得到了日志文件,并且可以在 Seq 上查看它们。最初我正在记录应用程序事件,但由于某种原因我不再得到它们。请参阅下面的图片。

日志中的应用程序事件 没有更多的应用程序事件

在第一张图片中,我正在获取应用程序事件。后来,当做同样的测试操作时,我不再得到应用程序事件,只有文件中的编码事件(即_logger.LogWarning("Warning");

我在 Main 方法中设置了 Serilog。

public static int Main(string[] args)
{
    var currentEnv = Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT");

    var configuration = new ConfigurationBuilder()
        .AddJsonFile("appsettings.json")
        .AddJsonFile($"appsettings.{currentEnv}.json", optional: true)
        .AddEnvironmentVariables()
        .Build();

    //Configure logger
    Log.Logger = new LoggerConfiguration()
        .ReadFrom.Configuration(configuration)
        .CreateLogger();

    Log.Information("Logger created");

    try
    {
        Log.Information("Starting web host");
        BuildWebHost(args).Run();
        return 0;
    }
    catch (Exception ex)
    {
        Log.Fatal(ex, "Web Host terminated unexpectedly");
        return 1;
    }
    finally
    {
        Log.CloseAndFlush();
    }
}

    public static IWebHost BuildWebHost(string[] args) =>
        WebHost.CreateDefaultBuilder(args)
            .UseStartup<Startup>()
            .Build();
}

我的 Serilog 设置

 "Serilog": {
  "Using": [
    "Serilog.Sinks.RollingFile",
    "Serilog.Sinks.Async",
    "Serilog.Sinks.ApplicationInsights",
    "Serilog.Sinks.Console",
    "Serilog.Sinks.Seq"
  ],
  "MinimumLevel": {
    "Default": "Information",
    "Override": {
      "Microsoft": "Warning"
    }
  },
  "WriteTo": [
    {
      "Name": "Async",
      "Args": {
        "configure": [
          {
            "Name": "RollingFile",
            "Args": { "pathFormat": "C:/Logs/Serilog/log-{Date}.log" }
          },
          {
            "Name": "Seq",
            "Args": { "serverUrl": "http://localhost:5341" }
          }
        ]
      }
    }
  ],
  "Enrich": [ "FromLogContext", "WithMachineName", "WithThreadId" ],
  "Properties": {
    "Application": "WebTemplate"
  }
}

在继续让 Serilog 更实用之前,我想弄清楚为什么我不再收到应用程序事件。

4

2 回答 2

4

我希望这取决于您的 Serilog 设置中的以下部分:

"MinimumLevel": {
    "Default": "Information",
    "Override": {
        "Microsoft": "Warning"
    }
}

Nicholas Blumhardt 的博客文章详细介绍了Override设置的工作原理:

因此,上述配置的效果是,当记录器由 Microsoft.* 命名空间中的类型拥有时,仅在警告级别或以上生成事件。

这句话似乎直接适用于您的情况,即您要求 Serilog 过滤掉属于 Microsoft.* 命名空间严重性低于Warning.

您在第一个屏幕截图中显示的消息来自 MVC 或实体框架,它们位于 Microsoft.* 命名空间中,并且将以低于警告的严重性记录。

于 2017-11-28T21:59:18.970 回答
0

看起来您UseSerilog()缺少BuildWebHost()

public static IWebHost BuildWebHost(string[] args) =>
    WebHost.CreateDefaultBuilder(args)
        .UseSerilog() // <- Add this line
        .UseStartup<Startup>()
        .Build();

这假设您已安装Serilog.AspNetCore NuGet 包。

于 2017-11-28T21:05:30.337 回答