Logstash StructuredArguments kv 正在以时间戳格式打印 ZonedDateTime 变量

问题描述

我正在使用 logstash KV 方法进行日志记录。因为我有一个作为字符串的键和一个作为对象的值。在日志中,对象被打印为 JSON,这是正确的。但是 JSON 对象中的一些变量最初是 zoneddatetime 以时间戳的形式打印在日志中。

例如其中一个变量在日志中打印为:

"createEventDateTime":1540849347.000000000  --> actual

"createEventDateTime":"2018-10-29T21:42:27Z"  --> Expected

解决方法

默认情况下,Jackson 将 ZonedDateTime 字段值写为数值。

要将 Jackson 配置为将它们编写为 ISO-8601 兼容字符串,请通过 WRITE_DATES_AS_TIMESTAMPS... 禁用 JsonFactoryDecorator 序列化功能

import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.databind.MappingJsonFactory;
import com.fasterxml.jackson.databind.SerializationFeature;
import net.logstash.logback.decorate.JsonFactoryDecorator;

public class TimestampJsonFactoryDecorator implements JsonFactoryDecorator {

    public JsonFactory decorate(JsonFactory factory) {
        ((MappingJsonFactory) factory).getCodec()
                .disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
        return factory;
    }
}

然后配置编码器以使用该装饰器...

    <encoder class="net.logstash.logback.encoder.LogstashEncoder">
        <jsonFactoryDecorator class="your.TimestampJsonFactoryDecorator"/>
    </encoder>

另见Customizing JSON Factory and Generator