logstash使用之日期处理

概述

日期插件Date filter plugin用于对logstash接收到的字段中的日期进行处理,可以使用处理后的日期作为logstash的timestamp.

日期进行处理后,可以在kibana中用于统计和分析.

参考

logstash帮助文档

简单使用

input{
        stdin{
        }
}
filter{
    date{
        match => ["message","yyyyMMdd"]
    }
}
output{
        stdout{codec => rubydebug}
}
  • 从标准控制台接收输入
  • 使用date插件过滤,这里是一个简单的配置,使用matchmessage字段中的内容进行时间转化,默认将转化后的结果放到了@timestamp中.
  • 使用标准控制台输出,输出使用了rubydebug插件,目的是输出调试结果看起来方便,内容也全面一些.

使用效果:

20171124
{
      "@version" => "1",
          "host" => "localhost",
    "@timestamp" => 2017-11-23T16:00:00.000Z,
       "message" => "20171124"
}
20171120
{
      "@version" => "1",
          "host" => "localhost",
    "@timestamp" => 2017-11-19T16:00:00.000Z,
       "message" => "20171120"
}

如上,2017112420171120是控制台输入的,其余内容时rubydebug插件输出的内容.可以看到:
* 输入的内容默认保存在了message字段中
* @timestamp随着message中的日期而改变了.
* @timestamp虽然改变了,但是和设置的时间不一样.

date插件默认的是将时间转化为 Zulu/UTC标准时间,也就是说,上面的时间我设置的是20171120,指的是当前时区的时间的20171120 00:00:00
但是,到了logstash中,被转为标准时间,也就是当前时区的时间-8小时,为20171119 16:00:00.

选项

date插件特有的选项如下:

  • local

    • string类型
    • 没有默认值

    用于指定本地方言,比如设置为en,en-US等.主要用于解析非数字的月,和天,比如Monday,May等.如果是时间日期都是数字的话,不用关心这个值.

  • match

    • array类型
    • 默认为[]

    用于将指定的字段按照指定的格式解析.比如:

    match => ["createtime", "yyyyMMdd","yyyy-MM-dd"]

    第一个值为字段名,其余值为解析的格式,如果有多个可能的格式,可以设置多个.

  • tag_on_failure

    • array类型
    • 默认为["_dateparsefailure"]

    添加一个值到tags字段中,如果日期解析失败.

  • target

    • string类型
    • 默认为@timestamp

    用于指定转化后的日期保存的字段名

  • timezone

    • string类型
    • 没有默认值

    用于为要被解析的时间指定一个时区,值为时区的canonical ID,可以在这里看到可以使用的值.

    一般不用设置,因为会根据当前系统的时区获取这个值.

    这里设置的时区并不是logstash最终储存的时间的时区,logstash最终储存的时间为UTC标准时间.

    比如这里设置时间为20171120:

    • 如果时区为Asia/Shanghai那么转化后的时间为2017-11-19T16:00:00.000Z;
    • 如果时区为Europe/Vienna那么转化后的时间为2017-11-19T23:00:00.000Z;

总结

提供一个解析通用的日期配置:

filter{
    date{
        match => ["fieldName", "yyyyMMdd","yyyy-MM-dd"]
        target => "fieldName1"
        timezone => "Asia/Shanghai"
    }
}
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Logstash是一个开源的数据收集引擎,它允许您从不同的来源收集、转换和发送数据。下面是一些关于Logstash使用的基本信息: 1. 安装:您可以从Elasticsearch官方网站下载并安装Logstash。根据您的操作系统,安装过程可能会有所不同。 2. 配置:一旦安装完成,您需要配置Logstash来定义输入、过滤器和输出。配置文件使用Ruby编写,并且遵循简单的语法规则。您可以指定从哪个来源(如文件、数据库、网络)收集数据,并使用过滤器对数据进行处理和转换。最后,您可以将处理后的数据发送到不同的目标,如Elasticsearch、Kafka等。 3. 输入插件:Logstash提供了各种输入插件,以便从不同的来源收集数据。例如,您可以使用file插件从文件中读取数据,使用jdbc插件从数据库中读取数据,使用beats插件从Beats数据发送器收集数据等。 4. 过滤器插件:Logstash还提供了许多过滤器插件,用于对收集到的数据进行处理和转换。您可以使用grok插件进行日志解析,使用mutate插件进行字段操作,使用date插件进行日期格式化等。 5. 输出插件:最后,Logstash允许您将处理后的数据发送到不同的目标。您可以使用elasticsearch插件将数据发送到Elasticsearch进行索引和存储,使用kafka插件将数据发送到Kafka消息队列等。 总的来说,Logstash是一个强大的工具,用于收集、转换和发送各种类型的数据。您可以根据自己的需求和数据来源选择适当的插件和配置。如果您需要更详细的使用指南,可以参考Logstash官方文档或者其他在线资源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值