如何解决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>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。