我的情况是:文件接收器应包含所有内容。另一个接收器应包含“信息”消息,但要注意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();
这是错误吗?为什么过滤器可以工作,但不能设置最低水平呢?
我相信这是我报告的同一错误,只是以不同的方式表现出来:
Bug: MinimumLevel override ignores
SourceContext
of LogEvent #1382
在这种情况下,SourceContext
将是一个不错的解决方法,直到修复了该错误。