当前位置: 首页 > 知识库问答 >
问题:

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

关学
2023-03-14
<?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>

当我尝试console appender并尝试打印该字段时,就像下面的示例一样,它起作用了。

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

你能告诉我我在udp appender上做错了什么吗?谢谢你的忠告。

共有1个答案

柯骏
2023-03-14

您使用的是UDP appender,它没有编码器。您应该使用TCP Appender(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>

看看我在这里创建的演示项目。

此代码(Kotlin):

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

LOG.warn("Warn")
<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>
{
    "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"
}

编辑

由于麋鹿的错误配置,你可能看不到你在基巴纳的能量场。我粘贴我的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}"
    }
}

然后,我用logback-*模式在Kibana中配置了日志:

 类似资料:
  • 问题内容: 如果类型不匹配,可以将一些元素追加到elasticsearch字段吗?如果我有这样的文件: 而且我想像这样附加另一个标签字段“蓝色”: 我想要的结果类似于: 我知道这个: 用于将字符串追加到另一个字符串 还有这个: 用于将另一个元素追加到列表。那么有什么办法可以将另一个元素附加到字符串字段呢?谢谢您的任何建议。 问题答案: 您可以做的是添加针对字段类型的测试,然后将其转换为数组。该脚本

  • 如果一个log4j属性有多个文件附加器,那么在Java中,我如何确保日志被写入一个特定的文件中。 在Java类中,我能做些什么来写一些消息,比如说,SUCCESS_FILE和一些消息TEMP_FILE

  • 使用命令: /usr/bin/journalctl-o short-f |ncat{some ip}{some port} 将日志输出转发到某个远程日志跟踪应用程序。 问题是,我在打印输出中缺少systemd单元/服务名称,因此很难判断哪个服务生成哪个日志行。 例如,这是一条nginx生产线: 6月25日07:51:09本地主机bash[497]:10.23.132.98---[25/Jun/20

  • 我试图添加额外的行李到HTTP服务器上的现有跨度,我想添加一个路径变量到跨度,从日志MDC访问,并通过超文本传输协议或kafka在电线上传播到下一个服务器。 我的设置:春云侦探霍克斯顿。SR5和Spring启动2.2.5 我尝试添加以下设置和配置: 并添加了http拦截器: 和http筛选器以影响当前范围(根据spring文档) 问题是日志不包含我的自定义上下文id,上下文类型,虽然是在span上

  • 问题内容: 我是ELK堆栈的新手。我有一个文件拍服务,将日志发送到logstash,并在logstash中使用过滤器,将数据推送到索引。 我正在使用筛选器来解析数据。 我的问题是,我希望将字段名称及其值存储在elasticsearch索引中。我的日志的不同版本如下: 我想要的弹性索引字段如下: client_ip => type必须与kibana用于IP映射的内容兼容。 时间戳=>日期时间格式。=

  • 在我的应用程序的logback.xml中,我有一个AsyncAppender定义如下。 当我在Windows10上部署Tomcat中的war时。 null 请各位专家告诉我,我在这里做错了什么?AsyncAppender是否有其他属性可以帮助修复此行为?