繁体   English   中英

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

[英]How can I override Serilog levels differently for different sinks?

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

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();

这是一个错误吗? 为什么过滤器有效但设置最低级别无效?

不幸的是,子记录器根本不支持MinimumLevel.Override() 在下面的问题中查看更多信息:

错误:MinimumLevel 覆盖忽略 LogEvent #1382 的SourceContext

.Filter.ByExcluding目前是一个很好的解决方法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM