目前的zabbix监控了900台左右服务器,大概有11万items,zabbix在工做时根据agent的工做特色分为主动模式和被动模式,实际上通常开启兼容模式。在items多了后,有一些速度慢的items若是不采用主动模式,会把server端拖死,而zabbix_sender实际上是一种变相的主动模式,配合计划任务,主动将k/v上传到zabbix,现将nginx日志zabbix_sender实现状态码的监控抛砖引玉作下介绍。
nginx
1、agent端编写脚本和计划任务bash
需求是监控nginx日志的200、400、40一、40三、40四、49九、50二、50三、504状态码,按分钟进行数量统计上报。编写脚本入下:服务器
#!/bin/bash #writer:gaolixu log_dir=/data1/ms/comos/logs/access.log #log目录 log_tmp_dir=/tmp/last_min_log #过滤出最后1分钟的日志作临时存放 senderfile=/tmp/sender_file #用zabbix_sender发送的k/v文件 Hostname=`hostname` #获取主机名,与server端主机名会有验证 last_min=`date -d "1 minute ago" '+%Y:%H:%M'` #nginx里的时间,1分钟以前 tail -60000 ${log_dir} |grep "${last_min}" > ${log_tmp_dir} #qps在500到800之间,增长性能,tail结尾60000条取出最后一分钟日志。 cat /tmp/last_min_log |awk -F'"' '{print $3}' |awk '{print $1}' |sort |uniq -c > /tmp/stat #将状态码去重统计 >$senderfile #清零zabbix_sender的发送文件 c_200=`awk '$2==200{print $1}' /tmp/stat`;[ -z $c_200 ] && c_200=0 #取出数量,若是没有此状态码,数量初始化为0 c_400=`awk '$2==400{print $1}' /tmp/stat`;[ -z $c_400 ] && c_400=0 c_401=`awk '$2==401{print $1}' /tmp/stat`;[ -z $c_401 ] && c_401=0 c_403=`awk '$2==403{print $1}' /tmp/stat`;[ -z $c_403 ] && c_403=0 c_404=`awk '$2==404{print $1}' /tmp/stat`;[ -z $c_404 ] && c_404=0 c_499=`awk '$2==499{print $1}' /tmp/stat`;[ -z $c_499 ] && c_499=0 c_502=`awk '$2==502{print $1}' /tmp/stat`;[ -z $c_502 ] && c_502=0 c_503=`awk '$2==503{print $1}' /tmp/stat`;[ -z $c_503 ] && c_503=0 c_504=`awk '$2==504{print $1}' /tmp/stat`;[ -z $c_504 ] && c_504=0 echo "$Hostname nginx_stat200 $c_200" >> $senderfile #将k/v写入zabbix_sender的发送文件,注意写法,主机名、key、value echo "$Hostname nginx_stat400 $c_400" >> $senderfile echo "$Hostname nginx_stat401 $c_401" >> $senderfile echo "$Hostname nginx_stat403 $c_403" >> $senderfile echo "$Hostname nginx_stat404 $c_404" >> $senderfile echo "$Hostname nginx_stat499 $c_499" >> $senderfile echo "$Hostname nginx_stat502 $c_502" >> $senderfile echo "$Hostname nginx_stat503 $c_503" >> $senderfile echo "$Hostname nginx_stat504 $c_504" >> $senderfile /usr/local/zabbix/bin/zabbix_sender -c /usr/local/zabbix/etc/zabbix_agentd.conf -i $senderfile #最终的向server发送
添加到计划任务:app
*/1 * * * * /usr/local/zabbix/script/nginxlog.sh 2>&1
2、配置server端和grafana进行绘图运维
配置项以下,将type设置为Zabbix trapper
ide
设置完毕后执行下脚本,结果以下:性能
最后将展现放在grafana里,效果以下:spa
自建我的原创站运维网咖社(www.net-add.com),新的博文会在网咖社更新,欢迎浏览。.net