logstash filter plugin 是否支持 JSON / Hash to String

发布于 2022-09-12 02:41:22 字数 449 浏览 23 评论 0

问题描述

历史原因,ELK 原索引使用了动态映射。
客户端日志打点数据模型未约定,多端打点的同一个字段使用了不同的数据类型,进而导致打点数据在提交到 ES 时,因为索引字段不同导致提交索引失败部分日志丢失。

eg.
iOS - ext.query => text
WeApp - ext.query => object

WeApp 的 ext.query 字段在 ELK 只需存储,无需支持检索、聚合。

解决思路

思路是在 logstash-filter-plugin 中找到可以把指定字段转换为 String 的方式。

检索了搜索引擎,但并没有找到比较合适的方式。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

小嗲 2022-09-19 02:41:22

用万能的 ruby 吧:

      ruby {
        init => 'require "json"'
        code => '
          query = event.get("[ext][query]")
          event.set("[ext][query]", query.to_json)
        '
      }
恍梦境° 2022-09-19 02:41:22

感谢 @fefe 的建议。

我试着简化了配置,可行。

ruby {
    code => "event.set('[ext][query]', event.get('[ext][query]').to_s) if event.get('[ext][query]')"
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文