这个文章是两年前发的,最近整理了一下系统使用。只针对nginx前端web进行简单监控,具体再根据业务需求进行详细调用。后续的web场景、后端的服务器 这里不包含,需单独做,另外日志分析不建议这里添加,以免增加 系统负载尤其是io。日志分析处理单独拿ELK或自主开发的系统监控。

1,nginx开启nginx-status支持。 未安装该模块的,可以参考 《原已经安装好的nginx如何查看已经安装模块和添加一个未被编译安装的模块》安装。 配置站点文件添加如下location模块:

    location = /nginx-status  {
        stub_status   on;
        access_log   off;
    }

开启以后访问http://www.21yunwei.com/nginx-status是如下结果:

Active connections: 11 server accepts handled requests 946 946 4249 Reading: 1 Writing: 1 Waiting: 9 2,配置zabbix 2.1 导入模板,并需要将监控的主机链接到该模板 链接: http://download.21yunwei.com/zabbix/nginx/tem_zbx_nginx.tar.gz 2.2 根据模板中的参数key写shell shell脚本获取参数如下:

#!/bin/bash #use zabbix to monitor nginx status #author:21yunwei #监控 httpd code,eg:500.多个站点可以考虑循环实现 。这里只针对自己博客21yunwei做状态码监控。 accesslog="/logs/nginx/21yunwei/21yunwei.log" cat ${accesslog} | awk '{print $8}' |sort |uniq | grep 500 >/dev/null 2>&1 ;httpcode=$? #监控nginx存活状态,基于端口监听。另外需加web url监控防止假死。 netstat -tnlp | grep 80 >/dev/null 2>&1 ;status=$? url="http://www.21yunwei.com/nginx-status" #监控参数匹配 case $1 in "active" ) /usr/bin/curl $url 2>/dev/null | grep -i $1 | awk '{print $NF}' ;; "accepts") /usr/bin/curl $url 2>/dev/null | awk 'NR==3{print $1}' ;; "handled") /usr/bin/curl $url 2>/dev/null | awk 'NR==3{print $2}' ;; "requests") /usr/bin/curl $url 2>/dev/null | awk 'NR==3{print $NF}' ;; "reading") /usr/bin/curl $url 2>/dev/null | awk 'NR==4{print $2}' ;; "writing") /usr/bin/curl $url 2>/dev/null | awk 'NR==4{print $4}' ;; "waiting") /usr/bin/curl $url 2>/dev/null | awk 'NR==4{print $NF}' ;; "ping") echo $status ;; "httpcode") echo $httpcode ;;

  • ) echo "argu error";; esac

chmod a+x nginx_zbx.sh chmod +s /bin/netstat 调整zabbix_agentd下的配置文件,添加如下参数:

#nginx monitor UserParameter=nginx.status[*],/home/yunwei/nginx_zbx.sh $1 配置完成以后重启agent服务。 1

简单的整个系统负载监控: 1

好了,获取成功。 这里只做了监控监控,知道 nginx的运行状态、连接数、、错误日志报警和防假死(web场景添加的)功能,自己想要监控nginx其他参数,请自行修改模板添加监控项并设置key,通过命令或shell获取 展现即可。

转载请注明:21运维 » 通过zabbix 3.4 实现nginx web监控