[英]Serilog-Sinks-Loki transmitting logs to Loki in big batches. How can I reduce batch amount?
[英]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()
。 在下面的问题中查看更多信息:
.Filter.ByExcluding
目前是一个很好的解决方法。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.