将特定的MDC字段附加到logstash日志中

2024-02-26

我正在尝试将自定义字段添加到 logback-spring.xml 中的 Logstash Appender 中,如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="stash" class="net.logstash.logback.appender.LogstashSocketAppender">
        <host>xx.xx.xx.xx</host>
        <port>xxxxx</port>
        <encoder class="net.logstash.logback.encoder.LogstashEncoder">
            <includeMdcKeyName>myField</includeMdcKeyName>
        </encoder>
</appender>

<root level="info">
    <appender-ref ref="stash" />
</root>

</configuration>

它给了我错误:

线程“main”中出现异常 java.lang.IllegalStateException:检测到 Logback 配置错误: ch.qos.logback.core.joran.spi.Interpreter@34:71 中出现错误 - [编码器] 没有适用的操作,当前 ElementPath 为 [[configuration][appender][encoder]]

当我尝试控制台附加程序并尝试打印该字段(如下面的示例所示)时,它起作用了。

<layout>
      <Pattern>%-4r [%thread] %-5level My Field: [%X{myField:--}] %msg%n</Pattern>
</layout>

你能告诉我 udp Appender 做错了什么吗?谢谢你的建议。


您正在使用一个UDP附加器 https://github.com/logstash/logstash-logback-encoder#udp-appender,并且它没有encoder。你应该使用TCP附加器 https://github.com/logstash/logstash-logback-encoder#tcp-appenders (LogstashTcpSocketAppender代替LogstashSocketAppender):

<appender name="stash" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
    <destination>xx.xx.xx.xx:xxxxx</destination>
    <encoder class="net.logstash.logback.encoder.LogstashEncoder">
        <includeMdcKeyName>myField</includeMdcKeyName>
    </encoder>
</appender>

看看我创建的演示项目here https://gitlab.com/madhead-playgrounds/so53558553.

这段代码 https://gitlab.com/madhead-playgrounds/so53558553/blob/master/src/main/kotlin/by/dev/madhead/playgrounds/so53558553/App.kt#L16-22(科特林):

MDC.put("mdc", "so53558553")

LOG.warn("Warn")

With a logback-spring.xml https://gitlab.com/madhead-playgrounds/so53558553/blob/master/src/main/resources/logback-spring.xml#L3-8像这样:

<appender name="logstash" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
    <destination>localhost:5000</destination>
    <encoder class="net.logstash.logback.encoder.LogstashEncoder">
        <includeMdcKeyName>mdc</includeMdcKeyName>
    </encoder>
</appender>

在 Logstash 中生成这样的记录:

{
    "level_value" => 30000,
            "mdc" => "so53558553",
           "port" => 35450,
    "logger_name" => "by.dev.madhead.playgrounds.so53558553.SpringBootConsoleApplication",
           "host" => "172.17.0.1",
       "@version" => "1",
     "@timestamp" => 2018-12-03T01:16:28.793Z,
    "thread_name" => "main",
        "message" => "Warn",
          "level" => "WARN"
}

如你所见,mdc值被 Logstash 视为LoggingEvent.

EDIT

由于 ELK 配置错误,您可能在 Kibana 中看不到您的字段。我正在粘贴我的 Logstash pipiline 配置(/etc/logstash/conf.d/01-input.conf)仅供参考(这是非常基本的):

input {
    tcp {
        port => 5000
        codec => json_lines
    }
}

output {
    elasticsearch {
        hosts => [ "localhost:9200" ]
        index => "logback-%{+YYYY.MM.dd}"
    }
}

然后我在 Kibana 中配置了日志logback-*图案:

瞧:

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

将特定的MDC字段附加到logstash日志中 的相关文章

随机推荐