首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用logstash处理多个json事件

使用logstash处理多个json事件
EN

Stack Overflow用户
提问于 2018-09-26 18:56:40
回答 1查看 224关注 0票数 0

我的配置如下:使用filebeat和logstash将应用实例的日志转发到elastic search。

代码语言:javascript
复制
   Apps
+--------+
| +--------+
| | +--------+     +----------+    +----------+
| | |   +--- |     |          |    |          |
+ | |   |file| --> | logstash | -->| elastic  |
  + |   |beat|     |   (1)    |    | search   |
    +--------+     +----------+    +----------+
                         |               |
             (not avail) X               | (query)
                         V               |
                   +----------+          V
                   |          |      +------+
                   | logstash |<-----| Json |
                   |   (2)    |      | file |
                   +----------+      +------+

我想测试logstash-2中的日志处理,但目前无法实现从logstash-1转发。因此,我尝试了以下操作:查询elasticsearch并检索文档的_source字段,我得到了一些如下的json文档:

代码语言:javascript
复制
{
 "@timestamp": <timestamp>,
 "@version": "1",
 "requestMethod": "PUT",
 "requestUri": "/api/endopoint",
 "servername": "myserver" 
 ....  many other fields
}
{
 "@timestamp": <timestamp>,
 "@version": "1",

}
... many other json objects

我的问题是,如何使用logstash处理来自elasticsearch查询的这些json文档?

我尝试使用多行编解码器,然后使用json过滤器来处理它们,但无法使其工作:下面是一次尝试:

代码语言:javascript
复制
input {
  file {
    path => "events.json"
    sincedb_path => "/dev/null"
    start_position => beginning
    codec => multiline {
       pattern => "^\}"    #end of each json object
       what => "previous"
    }
  }
}

filter {
  json {
    source => "event"
  }
 }

 output {
  stdout{}
}
EN

回答 1

Stack Overflow用户

发布于 2018-09-26 22:26:49

经过一些额外的研究,我意识到多行编解码器配置是错误的。我已经修复了,现在我在消息字段上有整个事件。

代码语言:javascript
复制
input {
  file {
    path => "events.json"
    sincedb_path => "/dev/null"
    start_position => beginning
    codec => multiline {
        pattern => "^\}"    #end of each json object
        negate => true
        what => "next"
    }
  }
}

filter {
  json {
    source => "message"
  }

  mutate {
    remove_field => ["message"]
  } 
} 

output {
 stdout{}
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52516118

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档