PART Ⅰ : 容器云OPENSHIFT
- 安装
- 数据持久化
- 集群管理
- 数据持久化
- 管理
- 网络
- 安全审计
- 工具应用部署
PART Ⅱ:容器云 KUBERNETES
- 基础
- 原理
- 系统应用/网络CNI/TRaefik
- 安装
- 集群管理
- 用户认证ServiceAccount与授权策略RBAC
- K8S应用管理工具Helm
- 问题
- 辅助工具
- Doing:K8S 多集群管理与网络互联
- VM On K8S
PART Ⅲ:持续集成与持续部署
- CICD优化总结
- Jenkins
- Gitlab
- Drone
- Nexus
- 配置
- 使用OrientDB Console在DB层面修改配置
- [设置SMTP邮件服务](https://www.wenjiangs.com/doc/krrcu7ebin9hh
- 仓库管理
- 数据备份恢复
- API
- Jenkins相关插件
- 配置
- SonarQube静态代码扫描分析
- LDAP
- Apollo
- 项目管理工具
- Jira
- Redmine
- Harbor
- Vault
- Alfred
- Web IDE: VSCode
- DolphinScheduler
PART Ⅴ:日志/监控/告警
- Logging
- Kafka/Zookeeper
- Filebeat
- Metrics
- Tracing
- Sentry日志聚合告警平台
PART Ⅵ:基础
- Docker
- Shell脚本
- Mave
- git
- 正则表达式
- SSL/TLS
- Ceph
- 性能压力测试
- PXE+Kickstart
- netboot.xyz
- Tool
- Windows
- MacOS小技巧
- Linux
- Linux排错优化
- iptables详解
- MySQL
- Redis
- 负载均衡与代理
- 代理服务器
- Nginx
- GitBook
- Telegram机器人
- OpenVPN Server
- iDRAC
- vSphere
- Raspberry Pi树莓派
- 钉钉机器人
- Aliyun CLI
- 音、视频处理工具:fffmpeg
- 图片处理工具:Imagemagick
- PDF处理工具:Ghostscript
- Nvidia
- Virtualbox 虚拟机管理
- 阿里云产品使用总结
- RustDesk:可自建远程控制软件
- Poste:自建邮件服务器
- 使用 Jlink构建最小化依赖的 JRE 环境
- Aria2
- Asuswrt-Merlin
- Trap:Shell脚本信号跟踪
- 零散知识汇总
- BarkServer通知
- Synology
PART Ⅶ:数据存储、处理
PART VIII:CODE
- Python学习笔记
- 基础语法
- statik 将静态资源文件打包到二进制文件中
- HTML/CSS 学习笔记
- JavaScript学习笔记
PART X:HACKINTOSH
PART XI:安全
Logstash与Sentry对接
Sentry作为一个日志异常告警平台,对于异常日志聚合的告警,功能很强大。而基于ELK的日志系统,只能采集、聚合、存储应用日志,无法针对日志中的异常进行检测,聚合告警。所以可以在Logstash采集过程中输出一份日志数据到Sentry中进行聚合告警。
logstash-output-sentry插件:https://github.com/javiermatos/logstash-output-sentry
相关文章:
- https://medium.com/@yscaliskan/how-to-use-logstash-along-with-sentry-6c3d27790a38
- https://clarkdave.net/2014/01/tracking-errors-with-logstash-and-sentry/
整体对接思路
- Filebeat file Input(多行采集+打标签) -------> Filebeat processor(添加字段) -------> Filebeat logatash output(输出到filebeat进行加工处理)
- Logstash beat input (监听) -------> Logstash dissect filter(判断符合标签的事件+从事件原始日志中映射提取字段) -------> Logstash sentry Output(输出到Sentry中)
Filebeat 采集、输出要求:
- 可以多行采集(设置上下日志事件的标识),多行采集的日志信息到统一放到日志事件的“message”字段中
- 添加采集的日志类型字段,添加与Sentry相关信息(sentry上项目的ID、key、Secret)的字段
- 删除一些默认添加的字段信息
- 以日志中该日志产生的时间为事件的时间,而不是采集时的时间为事件时间
Logtash 接收、处理要求:
- 根据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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论