logstash如何将日志中字符串类型的时间转化成@timestamp

来源:互联网 发布:unity3d官方视频教程 编辑:程序博客网 时间:2024/05/16 05:40

ELK组合中我们在outputs/elasticsearch中常用的%{+YYYY.MM.dd}来创建索引,而这种写法是必须要读@timestamp这个字段的。默认情况下@timestamp字段显示的是当前时间,但我们可能需要记录的是日志中的字符串类型的时间,所以我们需要把日志中字符串类型的时间覆盖掉@timestamp中的当前时间。

 

创建配置文件 code.conf

input  {

     stdin{}

}

filter {

    grok {

        match => ["message", "%{TIMESTAMP_ISO8601:logdate}"]

    }

    date {

        match => ["logdate", "yyyy-MM-dd HH:mm:ss,SSS"]

        target => "@timestamp"

    }

}

output{

     stdout{

     codec=>rubydebug{}

     }

}

说明:标红出为日志中的时间格式,这个根据具体的日志自行修改或自己开发正则去匹配。

      这里我用的是logstash自带的正则。要查看自带了哪些正则可查看文件:/logstash-2.2.0/vendor/bundle/jruby/1.9/gems/logstash-patterns-core-2.0.2/patterns/grok-patterns

 

测试:

./logstash -f code.conf

手动输入:

     2016-08-24 18:05:39,830

 

可以看到@timestamp字段已经被覆盖。最后别忘了删除logdate字段

     mutate {

        remove => ["logdate"]

    }


关于kafka与logstash数据交互

关于logstash数据进elasticsearch

0 0
原创粉丝点击