如何针对不同的接收器以不同的方式覆盖Serilog级别?

问题描述 投票:1回答:1

我的情况是:文件接收器应包含所有内容。另一个接收器应包含“信息”消息,但要注意Microsoft。*消息很烦人,因此这些消息应仅限于“警告”。如何分别配置两个接收器?我尝试的第一件事是:

string outputTemplate = "[{Level:u3}] {SourceContext}: {Message:lj}{NewLine}";

Log.Logger = new LoggerConfiguration()
    .MinimumLevel.Verbose()
    .WriteTo.File("Logs/all.log", outputTemplate: outputTemplate)

    .MinimumLevel.Information()
    .MinimumLevel.Override("Microsoft", Serilog.Events.LogEventLevel.Warning)
    .WriteTo.File("Logs/some.log", outputTemplate: outputTemplate)
    .CreateLogger();

var msLogger = Log.Logger.ForContext(Constants.SourceContextPropertyName, "Microsoft.AspNet.Example");
var logger = Log.Logger.ForContext(Constants.SourceContextPropertyName, "MyClass");

msLogger.Verbose("example log; should not go in the minimal file");
msLogger.Information("example log; should not go in the minimal file");
msLogger.Warning("example log");
logger.Verbose("example log; should not go in the minimal file");
logger.Information("example log");

在这种情况下,两个日志文件都是选择性的,“ all.log”不包含所有日志消息。接下来,我尝试使用子记录器来完成此操作:

Log.Logger = new LoggerConfiguration()
    .MinimumLevel.Verbose()
    .WriteTo.File("Logs/all.log", outputTemplate: outputTemplate)

    .WriteTo.Logger(lc => lc
        .MinimumLevel.Information()
        .MinimumLevel.Override("Microsoft", Serilog.Events.LogEventLevel.Warning)
        .WriteTo.File("Logs/some.log", outputTemplate: outputTemplate))
        .CreateLogger();

此配置效果更好,但较小的日志文件仍包含此行,该行应已由.MinimumLevel.Override()选项阻止:

[INF] Microsoft.AspNet.Example: example log; should not go in the minimal file

使用过滤器确实有效,但是我更喜欢简单的语法,因此更易于配置。

Log.Logger = new LoggerConfiguration()
    .MinimumLevel.Verbose()
    .WriteTo.File("Logs/all.log", outputTemplate: outputTemplate)

    .WriteTo.Logger(lc => lc
        .MinimumLevel.Information()
        .Filter.ByExcluding(logEvent =>
            logEvent.Level < LogEventLevel.Warning &&
            Matching.FromSource("Microsoft").Invoke(logEvent))
        .WriteTo.File("Logs/some.log", outputTemplate: outputTemplate))
        .CreateLogger();

这是错误吗?为什么过滤器可以工作,但不能设置最低水平呢?

c# serilog
1个回答
1
投票

我相信这是我报告的同一错误,只是以不同的方式表现出来:

Bug: MinimumLevel override ignores SourceContext of LogEvent #1382

在这种情况下,SourceContext将是一个不错的解决方法,直到修复了该错误。

© www.soinside.com 2019 - 2024. All rights reserved.