3

我在 SpringBoot 应用程序中使用 Logback 和 Logstash。

在 logback.xml 我有一个带有服务名称的属性,就像:

<configuration>

<include resource="org/springframework/boot/logging/logback/defaults.xml" />

<include resource="org/springframework/boot/logging/logback/console-appender.xml" />

<property name="spring.application.name" calue="service"/>

<appender name="stash" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
    <destination>localhost:9600</destination>
    <encoder class="net.logstash.logback.encoder.LogstashEncoder"/>
</appender>

<root level="INFO">
    <appender-ref ref="CONSOLE" />
    <appender-ref ref="stash" />
</root>

</configuration>

Logstash conf 文件如下所示:

input{ tcp{
        port=> 9600
        host=>logstash
    }
}

filter {
grok {
match => {
  "message" =>
  "^%{TIMESTAMP_ISO8601:timestamp}\s+%{LOGLEVEL:level}\s+%{NUMBER:pid}\s+---\s+\[\s*%{USERNAME:thread}\s*\]\s+%{JAVAFILE:class}\s*:\s*%{DATA:themessage}(?:\n+(?<stacktrace>(?:.|\r|\n)+))?$"
}
}
date {
match => [ "timestamp" , "yyyy-MM-dd HH:mm:ss.SSS" ]
}
 mutate {
remove_field => ["@version"]
add_field => {
  "appid" => "%{[path]}"
}
add_field => {
  "levell" => "level"
}
add_field => {
  "mensage" => "message"
}
 }
   }
output{

 elasticsearch {
hosts => ["elasticsearch"]
index => "indice"
 }
   stdout{}
 } 

如何将 logback 文件中的应用程序名称属性添加为字段?

4

2 回答 2

11

您可以为 LogstashEncoder 配置自定义字段,如下所示

<appender name="stash" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
    <destination>192.168.99.100:4560</destination>

    <!-- encoder is required -->
    <encoder class="net.logstash.logback.encoder.LogstashEncoder">
      <customFields>{"appname":"${appName}"}</customFields>
    </encoder>
</appender>

例如,对于 spring boot 应用程序,您可以使用获取 spring 范围属性,如下所示

<springProperty name="appName" source="spring.application.name"/>

或者从 .properties 文件中导入属性

<property  resource="application.properties" />
于 2017-03-19T19:41:49.743 回答
2

从 logstash-logback-encoder 文档:

默认情况下,Logback 的 Context (ch.qos.logback.core.Context) 的每个属性,例如 HOSTNAME,都会作为一个字段出现在 LoggingEvent 中。这可以通过在编码器/布局/附加器配置中指定 false 来禁用。

默认情况下,您的 logback 属性是本地范围的,不包括在内。尝试将它们设置为scope="context".

<property name="spring.application.name" value="service" scope="context"/>
于 2016-12-23T00:43:09.400 回答