繁体   English   中英

Serilog .NET 核心:过滤请求日志并将它们发送到单独的接收器

[英]Serilog .NET core: Filter Request logging and send them to a separate sink

我想将我的请求日志保存在单独的日志文件中。 我似乎找不到过滤请求登录跟踪的方法app.UseSerilogRequestLogging(); .

有没有办法实现这一目标? 我没有找到任何文档。

这是我尝试使用的 API,尽管我没有找到任何表明该事件是请求日志记录事件的属性。

.WriteTo.Logger(config => config
        .MinimumLevel.Verbose()
        .Filter.ByIncludingOnly(e => e.Level == LogEventLevel.Debug)

来自UseSerilogRequestLogging请求日志都具有相同的模板,因此您可以使用:

  .Filter.ByIncludingOnly(e => e.MessageTemplate.Text == 
    "HTTP {RequestMethod} {RequestPath} responded {StatusCode} in {Elapsed:0.0000} ms")

(假设您使用的是默认模板。)

或者,因为它们都来自同一个类:

var requestLogs = Matching.FromSource("Serilog.AspNetCore.RequestLoggingMiddleware");

// ... then:
  .Filter.ByIncludingOnly(requestLogs)

暂无
暂无

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

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