Logstash整合zabbix 过滤Nginx 错误日志并进行报警
admin
2023-03-23 15:20:01
0



通过logstash过滤nginx-error日志,筛选日志中比较严重报错,并进行报警。

由于网络上很多帖子都是要么写了怎么筛选报错,要么就只翻译了logstash-zabbix-output插件的使用说明,并没有一个完整的配置,整个项目做完,整理出来供大家阅读。 


【软件版本】

zabbix 版本:2.4.8 
logstash 版本:2.4.0 
JDK 版本: 1.8.0_101 


【zabbix配置】 
首先配置zabbix的item,使其能够成功接收logstash发送过来的信息. 
创建Template:“Configuration” -> “Templates” -> “Create template”

Logstash整合zabbix  过滤Nginx 错误日志并进行报警


这里我对Template的名字叫“Log file check” 
然后创建Application:“Create applicaton”


Logstash整合zabbix  过滤Nginx 错误日志并进行报警



Application名字还叫“Log file check” 
最后创建item:“Create item”: 
注意四个地方:
Type 一定要选择“Zabbix trapper”,否则无法接收logstash发送的信息; 
Key 一定要写正确,最好不要有空格,需要在logstash中配置; 
Type of information 选择 “Text”,因为我传过来的值是一段报错日志,所以选择文本; 
Allowed hosts:允许传送的主机,一定要设定为logstash所在的主机。


Logstash整合zabbix  过滤Nginx 错误日志并进行报警


【Logstash配置】


注:logstash的下载及安装不介绍。 


安装目录:/opt/logstash/ 


由于日志量并没有达到上W级,因此针对logstash进行了一些优化,降低了部分性能: 

# vim /opt/logstash/bin/logstash 

LS_HEAP_SIZE=500m 
LS_JAVA_OPTS="-server -Xmx200m"

【安装logstash-output-zabbix插件】


/opt/logstash/bin/logstash-plugin install logstash-output-zabbix


logstash 配置文件: 


input { 
    file { 
        type => "error-log" # 指定类型,用于以后判断操作 
        path => "/tmp/test.log" # 文件路径 
        start_position => "beginning" # 文件开始位置 
        codec => multiline { # 使用多行匹配方式进行过滤 
            pattern => "^\d{4}" # 以4个数字开头的为第一行, 
            negate => true # 所有不以4个数字开头的,均归于上一行(下面what配置) 
            what => "previous" 
        }
    } 
}

filter {
    grok {    
        match => {         
            message:\s+\n.*Code:(?\d+).*Message:(?.+)\n.*File:(?.+)\n.*Line:(?\s+\d+).*"     # 对于匹配规则,还是要针对自己场景自己写    }       add_tag => [ "zabbix-sender" ]  # 添加一个标签    add_field => [                  # 设定agent主机的主机名和key的映射        "zabbix_host", "web01",     # 主机名        "zabbix_key", "logstash"    # 添加item时,设定的key名称    ]}    if "_grokparsefailure" in [tags] {          # 如果过滤报错,那么移除报错标签,不进行其他处理        mutate {            remove_tag => "_grokparsefailure"        }    }
}
output { # 输出配置 
    stdout { # 测试时可以开启终端输出 
        codec => rubydebug 
        #codec => json # 可以选择json格式的输出还是rubydebug格式的输出 
    } 
    zabbix { # 发送给zabbix的配置 
        zabbix_host => "zabbix_host" # zabbix_host指上面映射的主机,不能用ip 
        zabbix_key => "zabbix_key" # zabbix_key指上面映射的key,意思就
                                     是发送给某主机的某key,值为zabbix_value 
        zabbix_server_host => "192.168.1.229" # zabbix server 
        zabbix_server_port => "10051" # zabbix server port 默认为10051 
        zabbix_value => "Message" # 要发送的key值 
    } 
}

如果需要进行测试,可以在zabbix agent使用zabbix_sender进行测试:


/opt/zabbix/sender -z zabbix-server -p port -s agentservername -k keyname -o keyvalue

所有配置完成后,可以在监测日志文件中输入一些测试数据,并在zabbix web上查看是否正常出现数据:



Logstash整合zabbix  过滤Nginx 错误日志并进行报警



【配置报警】 
“configuration” -> “Templates” -> “Triggers” -> “Create Trigger”: 
Name:log error check 
Expression:判断获取值的长度是否为0,如果不为0,trigger为problem状态,发送报警 


Logstash整合zabbix  过滤Nginx 错误日志并进行报警


其他关于报警相关配置请自行某度······


参考资料:

http://blog.sina.com.cn/s/blog_7ba28b620102xw2w.html

https://www.elastic.co/guide/en/logstash/current/plugins-outputs-zabbix.html

https://www.zabbix.org/wiki/Docs/protocols/zabbix_sender/2.0

相关内容

热门资讯

女子出租屋凌晨疑遭陌生人闯入,... 极目新闻记者 郭奕据红星新闻报道,居住在杭州的女子小鱼(化名)在社交媒体上发布了一段拍摄于4月28日...
唐山市委书记调整 澎湃新闻记者 岳怀让据河北卫视《河北新闻联播》消息,河北省委常委常斌已任唐山市委书记。公开资料显示,...
视频丨开工忙、消费旺、出口强 ... 国家发展改革委国家信息中心今天发布4月份经济各领域先行指标,显示出经济稳步向好的大趋势。
喷了光触媒的物品在车里可以除甲... 最佳回答 可以的,效果挺好的。光催化剂中的催化剂可以氧化分解各种有机污染物和无机污染物,在空气中与...
家庭装修走暗线还是明线好? 个人认为装修的话选择暗线好些 1、由于走暗线带来的美观效果非常强,因此成为大多数人的首选...
朗逸钥匙装饰盖怎么取下 将遥控钥匙有标志的一面向上,用扁的小起子撬进缝隙的中部,钥匙会分开一个缝,按中缝将钥匙分开即可。既然...
不平整的墙面怎么装饰 不平等的墙可以请专门的画腻子画的大师去进行创作。现在很多的墙面,人家都用刮腻子的方式去做壁画。像那种...
明线安装和暗线安装应该怎么选择... 随着社会发展,人们生活水平提高,大部分农村家庭都能盖上一层或者几层楼房,楼层盖好后接下来就是装修的问...
“华盛顿”号航母驶离日本横须贺... △“乔治·华盛顿”号核动力航空母舰(资料图)当地时间10日上午,美国“乔治·华盛顿”号核动力航母完成...
司机因操作不当引发车祸致2死6... 极目新闻记者 谢茂5月10日13时40分许,重庆黔江区一处十字路口发生一起交通事故。据重庆市公安局黔...