我尝试使用一些富集程序(现在的机器名和线程ID)以及滚动文件接收器和Loggly接收器。虽然Loggly事件正确包含机器名称和线程ID属性,但我无法在滚动文件事件中看到这些。
这是我的xml /代码配置:
<add key="serilog:minimum-level" value="Information" />
<add key="serilog:write-to:RollingFile.pathFormat" value="C:\Foo\bar-{Date}.txt" />
<add key="serilog:using" value="Serilog.Sinks.Loggly" />
<add key="serilog:write-to:Loggly.inputKey" value="redacted Loggly key" />
new LoggerConfiguration()
.ReadAppSettings()
.Enrich.WithMachineName()
.Enrich.WithThreadId()
.CreateLogger()
有没有人设法做到这一点?这种行为是设计还是滚动文件接收器不支持这些丰富?
答案 0 :(得分:13)
将machinename和threadid作为属性添加到所有日志事件中。它们不在messageformat中,因此serilog不会将它们转换为文本表示。 然而,他们将被送到水槽。 Loggly接收器将选择所有属性(包括线程ID等)并将其转换为Loggly理解的东西(因为它可以接受任何类型的数据)。
如果您希望RollingFile接收器也输出机器名等,则需要调整te输出模板。因此将其设置为例如:
outputTemplate: "{Timestamp:HH:mm} [{Level}] {MachineName} ({ThreadId}) {Message}{NewLine}{Exception}"
另见https://github.com/serilog/serilog/wiki/Configuration-Basics#enrichers
由于滚动文件接收器无法输出所有属性,因此您只能获取默认情况下不包含这些属性的呈现消息。
答案 1 :(得分:0)
如果您没有看到像这样的丰富添加的属性
.Enrich.WithProperty("Assembly", assemblyName.Name)
问题可能与@Michel建议的outputTemplated有关。您需要为此添加一个outputTemplate。
添加输出模板的另一种方法是添加格式化程序。 首先安装Serilog.Formatting.Compact。然后,您必须指定一个格式化程序。 我在appsettings中使用了格式化程序,如下所示。
"Serilog": {
"WriteTo": [
{
"Name": "Seq",
"Args": {
"serverUrl": "http://localhost:5341",
"formatter": "Serilog.Formatting.Json.JsonFormatter, Serilog"
}
}
]
},
您看到的JsonFormatter是可用于nuget的格式化程序。 现在我所有的浓缩器都在任何地方都没有任何outputTemplate的情况下工作。
有关更多详细信息,请参见下一页。 https://github.com/serilog/serilog/wiki/Formatting-Output