0

我正在使用 .Net Core 3.1 和 Serilog,但日志输出有一个小而烦人的问题。

配置

appsettings.json的是

{
  "Serilog": {
    "Properties": {
      "Application": "Testing GZip"
    },
    "WriteTo": [
      {
        "Name": "Debug",
        "Args": {
          "outputTemplate": "[{Timestamp:o}] [{Level,3:u}] [{MachineName}/{ProcessName}:{ProcessId}/{ThreadName}:{ThreadId}] [{Application}/{SourceContext}] {Message}{NewLine}{Exception}{Properties:j}"
        }
      }
    ],
    "Enrich": [ "WithMachineName", "WithProcessName", "WithProcessId", "WithThreadName", "WithThreadId", "WithExceptionDetails" ]
  }
}

问题

如您所见,如果您想记录异常和异常详细信息,我的outputTemplate结尾是并且这是强制性的。{NewLine}{Exception}{Properties:j}

不幸的是,我注意到输出的格式不正确。看看这里:

[2020-04-10T13:58:16.5592267+02:00] [INFORMATION] [PRO4-AEG/Test_Serilog_Logging:8096/:1] [Testing GZip/object] Start logging
{}[2020-04-10T13:58:16.6547724+02:00] [INFORMATION] [PRO4-AEG/Test_Serilog_Logging:8096/:1] [Testing GZip/object] Test1
{}Exception thrown: 'System.ArgumentNullException' in Test_Serilog_Logging.dll
{}[2020-04-10T13:58:16.6755158+02:00] [ERROR] [PRO4-AEG/Test_Serilog_Logging:8096/:1] [Testing GZip/object] You wrote 'THIS IS A TEST!' - Test_Serilog_Logging.TestClass
System.ArgumentNullException: Value cannot be null. (Parameter 'argument')
   at Test_Serilog_Logging.TestClass.TestLogging() in C:\Users\attil\source\repos\Test_Serilog_Logging\Test_Serilog_Logging\TestClass.cs:line 25
{"ExceptionDetail":{"Type":"System.ArgumentNullException","HResult":-2147467261,"Message":"Value cannot be null. (Parameter 'argument')","Source":"Test_Serilog_Logging","ParamName":"argument"}}[2020-04-10T13:58:16.7337262+02:00] [INFORMATION] [PRO4-AEG/Test_Serilog_Logging:8096/:1] [Testing GZip/object] Stop logging
{}The program '[8096] Test_Serilog_Logging.exe' has exited with code 0 (0x0).

正如您在第一个日志事件之后看到的那样,Serilog 开始在该行前面加上两个字符{},如果我{Properties:j}从配置文件中删除 ,它就会消失。

有什么想法可以解决这个问题吗?

谢谢你。阿蒂利奥

4

2 回答 2

2

每行的{}开头是您的Propertiesas JSON(一个空对象)的内容,因为您没有为这些日志消息定义任何属性。由于您定义输出模板的方式,它出现在下一行的开头:

{Message}{NewLine}{Exception}{Properties:j}

这导致在异常详细信息和属性之前{NewLine}添加a 。

如果您将 改为添加{NewLine}到输出模板的末尾,您将{}在同一行获得...

{Message}{Exception}{Properties:j}{NewLine}
于 2020-04-15T21:35:01.060 回答
2

可能考虑的一种选择是使用 Serilog 格式化程序,例如Serilog.Formatting.Json.JsonFormatteror - 有关格式化输出Serilog.Formatting.Compact.CompactJsonFormatter的更多信息,请参阅 Serilog wiki ,以及有关如何配置此 appsettings.json 文件的下图。或者,您可以创建自己的自定义格式化程序 -有关示例,请参见CompactJsonFormatter 。

在此处输入图像描述

于 2020-04-15T23:19:38.133 回答