返回介绍

PART Ⅰ : 容器云OPENSHIFT

PART Ⅱ:容器云 KUBERNETES

PART Ⅲ:持续集成与持续部署

PART Ⅴ:日志/监控/告警

PART Ⅵ:基础

PART Ⅶ:数据存储、处理

PART VIII:CODE

PART X:HACKINTOSH

PART XI:安全

Logstash与Sentry对接

发布于 2024-06-08 21:16:46 字数 8365 浏览 0 评论 0 收藏 0

Sentry作为一个日志异常告警平台,对于异常日志聚合的告警,功能很强大。而基于ELK的日志系统,只能采集、聚合、存储应用日志,无法针对日志中的异常进行检测,聚合告警。所以可以在Logstash采集过程中输出一份日志数据到Sentry中进行聚合告警。

logstash-output-sentry插件:https://github.com/javiermatos/logstash-output-sentry

相关文章:

  1. https://medium.com/@yscaliskan/how-to-use-logstash-along-with-sentry-6c3d27790a38
  2. https://clarkdave.net/2014/01/tracking-errors-with-logstash-and-sentry/

整体对接思路

  1. Filebeat file Input(多行采集+打标签) -------> Filebeat processor(添加字段) -------> Filebeat logatash output(输出到filebeat进行加工处理)
  2. Logstash beat input (监听) -------> Logstash dissect filter(判断符合标签的事件+从事件原始日志中映射提取字段) -------> Logstash sentry Output(输出到Sentry中)

Filebeat 采集、输出要求:

  1. 可以多行采集(设置上下日志事件的标识),多行采集的日志信息到统一放到日志事件的“message”字段中
  2. 添加采集的日志类型字段,添加与Sentry相关信息(sentry上项目的ID、key、Secret)的字段
  3. 删除一些默认添加的字段信息
  4. 以日志中该日志产生的时间为事件的时间,而不是采集时的时间为事件时间

Logtash 接收、处理要求:

  1. 根据filebeat传送过来的事件中的类型字段判断是否进行过滤加工

以API网关Kong的Nginx的错误日志为例(该Nginx安装了LUA模块,错误日志里面有lua模块的错误日志)。日志文件中的一行代表着一个nginx出错的事件,示例如下:

2018/11/28 18:16:25 [warn] 2201#0: 9081632 [lua] cluster.lua:182: set_peer_down(): [lua-cassandra] setting host at 172.17.1.8 DOWN, context: ngx.timer 2018/11/28 18:16:25 [error] 2201#0: 9081632 [lua] init.lua:365: [cluster_events] failed to poll: failed to retrieve events from DB: [Unavailable exception] Cannot achieve consistency level LOCAL_ONE, context: ngx.timer 2019/11/28 18:16:26 [warn] 27201#0: 90815632 this is a warn log event 2019/11/28 18:16:26 [fatal] 27201#0: 90815632 this is a fatal log event

每一行日志可大致格式分为:

时间戳 日志级别 进程号 抛弃该处数据 具体错误日志

1. Filebeat配置

filebeat.inputs:
  - type: log
    enabled: true
    paths: 
      - /root/Curiouser/test.log
    exclude_files: ["_filebeat", ".gz$"]
    recursive_glob.enabled: true
    multiline.pattern: '^[0-9]{4}/[0-9]{2}/[0-9]{2} [0-9]{2}:[0-9]{2}:[0-9]{2}'
    multiline.negate: true
    multiline.match: after
    tags:
      sentry-alert
    fields:
      service_name => "kong"
      sentry_project_id => "7"
      sentry_project_key => "***"
      sentry_project_secret => "***"
processors:
- drop_fields:
    fields: ["agent", "tags", "input", "ecs"]
output.logstash:
  hosts: ["127.0.0.1:5044"]

2. Logstash安装sentry output插件

/usr/share/logstash/bin/logstash-plugin install logstash-output-sentry
/usr/share/logstash/bin/logstash-plugin list

2. Logstash配置

input {
  beats {
    port => 5044
  }
}
filter {
 # 判断"tag"包含"log-alert"标签的日志事件进行加工处理
 if [tags] == "log-alert" {
    # 映射原始日志,从中提取数据赋予指定的字段(按行为单位)
    dissect {
       mapping => {
         "message" => "%{timestamp} %{+timestamp} [%{level}] %{thread} %{} %{message}"
      }
    }
    # 提取日志的产生时间作为事件的时间戳。
    date {
      match => [ "timestamp", "yyyy/MM/dd HH:mm:ss" ]
      remove_field => "timestamp"
    }
    # 替换原始日志中的日志级别字段,sentry支持的日志级别为warning,而原始日志中的日志级别字段是warn,索引需要转换。
    mutate {
      gsub => [ "level", "warn", "warning" ]
    }
  }    
}
output {
  # 判断日志级别为"warning","error","fatal"的日志事件,发送到sentry
  if [level] == "warning" or [level] == "error" or [level] == "fatal"  {  
    sentry {
      message => "message"
      threads => 'thread'
      level => "level"
      tags =>  'service:"service_name"'

      url => "http://sentry.curiouser.com/api"
      key => '%{sentry_project_key}'
      secret => '%{sentry_project_secret}'
      project_id => '%{sentry_project_id}'
    }
  }
}

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

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

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文