NLog 布局

编辑

此布局实现将 NLog 事件格式化为符合 Elastic 通用架构规范的 JSON 表示形式。

安装

编辑

添加对 Elastic.CommonSchema.NLog 包的引用

<PackageReference Include="Elastic.CommonSchema.NLog" Version="8.6.0" />

用法

编辑

以编程方式设置

编辑
Layout.Register<EcsLayout>("EcsLayout"); // Register the ECS layout.
var config = new LoggingConfiguration();
var consoleTarget = new ConsoleTarget("console") { Layout = new EcsLayout() };  // Use the ECS layout.
config.AddRule(LogLevel.Debug, LogLevel.Fatal, consoleTarget);
LogManager.Configuration = config;
var logger = LogManager.GetCurrentClassLogger();

在上面的代码片段中,Layout.Register<EcsLayout>("EcsLayout")EcsLayout 注册到 NLog。然后,Layout = new EcsLayout() 行指示 NLog 使用已注册的布局。上面的示例使用控制台目标,但您可以随意使用任何您选择的目标;也许可以考虑使用文件系统目标和 Elastic Filebeat 来实现持久可靠的摄取。

使用 NLog.config 设置

编辑
<nlog>
  <extensions>
    <add assembly="Elastic.Apm.NLog"/>
    <add assembly="Elastic.CommonSchema.NLog"/>
  </extensions>
  <targets>
    <target name="console" type="console">
      <layout xsi:type="EcsLayout">
        <metadata name="MyProperty" layout="MyPropertyValue" /> <!-- repeated, optional -->
        <label name="MyLabel" layout="MyLabelValue" />          <!-- repeated, optional -->
        <tag layout="MyTagValue" />                             <!-- repeated, optional -->
      </layout>
    </target>
  </targets>
  <rules>
    <logger name="*" minLevel="Debug" writeTo="Console" />
  </rules>
</nlog>

EcsLayout 参数选项

编辑
  • 元数据选项
  • IncludeEventProperties - 包含 LogEvent 属性作为元数据。默认值:true
  • IncludeScopeProperties - 包含 NLog 范围上下文属性作为元数据。默认值:false
  • ExcludeProperties - 用逗号分隔的字符串,其中包含要排除的属性名称。
  • 事件选项
  • EventAction -
  • EventCategory -
  • EventId -
  • EventKind -
  • EventSeverity -
  • 代理选项
  • AgentId -
  • AgentName -
  • AgentType -
  • AgentVersion -
  • 进程选项
  • ProcessExecutable - 默认值:${processname:FullName=true}
  • ProcessId - 默认值:${processid}
  • ProcessName - 默认值:${processname:FullName=false}
  • ProcessThreadId - 默认值:${threadid}
  • ProcessTitle - 默认值:${processinfo:MainWindowTitle}
  • 服务器选项
  • ServerAddress -
  • ServerIp -
  • ServerUser - 默认值:${environment-user}
  • 主机选项
  • HostId -
  • HostIp - 默认值:${local-ip:cachedSeconds=60}
  • HostName - 默认值:${machinename}
  • 日志来源选项
  • LogOriginCallSiteMethod - 默认值:${exception:format=method}
  • LogOriginCallSiteFile - 默认值:${exception:format=source}
  • LogOriginCallSiteLine -
  • HTTP 选项
  • HttpRequestId - 默认值:${aspnet-trace-identifier}
  • HttpRequestMethod - 默认值:${aspnet-request-method}
  • HttpRequestBytes - 默认值:${aspnet-request-contentlength}
  • HttpRequestReferrer - 默认值:${aspnet-request-referrer}
  • HttpResponseStatusCode - 默认值:${aspnet-response-statuscode}
  • URL 选项
  • UrlScheme - 默认值:${aspnet-request-url:IncludeScheme=true:IncludeHost=false:IncludePath=false}
  • UrlDomain - 默认值:${aspnet-request-url:IncludeScheme=false:IncludeHost=true:IncludePath=false}
  • UrlPath - 默认值:${aspnet-request-url:IncludeScheme=false:IncludeHost=false:IncludePath=true}
  • UrlPort - 默认值:${aspnet-request-url:IncludeScheme=false:IncludeHost=false:IncludePath=false:IncludePort=true}
  • UrlQuery - 默认值:${aspnet-request-url:IncludeScheme=false:IncludeHost=false:IncludePath=false:IncludeQueryString=true}
  • UrlUserName - 默认值:${aspnet-user-identity}
  • 跟踪选项
  • ApmTraceId - 默认值:${ElasticApmTraceId}
  • 事务选项
  • ApmTransactionId - 默认值:${ElasticApmTransactionId} *

支持 ECS 的消息模板

编辑

此外,还支持 LogTemplateProperties.* 下可用的任何有效的 ECS 日志模板属性,例如 LogTemplateProperties.TraceId,它将直接设置相应的 ECS 字段。

logger.Info("The time is {TraceId}", "my-trace-id");

将覆盖生成的 ECS json 文档中的 trace.id

EcsLayout 的示例输出

编辑

下面给出了输出示例

{
   "@timestamp":"2020-02-20T16:07:06.7109766+11:00",
   "log.level":"Info",
   "message":"Info \"X\" 2.2",
   "metadata":{
      "value_x":"X",
      "some_y":2.2
   },
   "ecs":{
      "version":"1.4.0"
   },
   "event":{
      "severity":6,
      "timezone":"AUS Eastern Standard Time",
      "created":"2020-02-20T16:07:06.7109766+11:00"
   },
   "host":{
      "name":"LAPTOP"
   },
   "log":{
      "logger":"Elastic.CommonSchema.NLog",
      "original":"Info {ValueX} {SomeY}"
   },
   "process":{
      "thread":{
         "id":17592
      },
      "pid":17592,
      "name":"dotnet",
      "executable":"C:\\Program Files\\dotnet\\dotnet.exe"
   }
}