Вы используете UDP appender , и у него нет encoder
.Вы должны использовать 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")
С logback-spring.xml
, как это:
<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 field">
Как видите, значения mdc
воспринимаются Logstash как поле в LoggingEvent
.
РЕДАКТИРОВАТЬ
Возможно, вы не видите свое поле в Кибане из-за неверной конфигурации ELK.Я вставляю свою конфигурацию 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-*
:
И вуаля: