logstash elasticsearch ealstalert 关于@timestamp的处理

一、需求

1、logstash采集日志数据,并将日志数据写入 ES 集群中,其中@timestamp采用北京时间(默认为ISO8601)

2、elastalert 间隔60秒运行一次规则文件,如果查询到匹配规则文件的日志,则告警。elastalert默认是查询 @timestamp,并在内部转换为 ISO8601 格式的时间。

二、解决方案

1、 logstash 执行时指定的配置文件,在采集日志写 ES前,修改 @timestamp时间,增加 8*60*60(北京时间)

2、logstash 执行时指定的配置文件,新增一个记录如utc_time,其值为 ISO8601 格式的 @timestamp ,用于 elastalert 查询使用

3、 elastalert 查询时的规则文件,增加 timestamp_field: utc_time (默认为 @timestamp)

三、对于的脚本

1、logstash 启动指定的脚本,这里使用 app-es.conf

       启动命令: ./logstash -f app-es.conf

input{
    file{
        path => "/home/app/testlog/test.log"
        start_position => "beginning"  # 每次从文件开头读取
        sincedb_path => "/dev/null"    # sincedb_path 记录读取位置,这里指向 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值