环境:
zabbix 2.0
Zabbix Server: 172.28.2.119
Zabbix nginx 客户端: 172.28.2.151

前提是nignx在编译安装时加上:--with-http_stub_status_module -----这个大家都知道!!

同时还要在nginx的配置文件中加上:

 
  
  1. location /status

  2.    {

  3.       stub_status on;

  4.       access_lod off;

  5.       allow 127.0.0.1;

  6.       allow 172.28.2.119;    #这是我们zabbix监控服务器IP

  7.    }

下面说下zabbixnginx的监控原理:

Zabbix Server <---(Zabbix Agent)---> nginx客户端key(要写入客户端配置文件中) <--- 脚本 --->nginx状态参数

nginx web界面nginx状态显示情况如下图:

【APP】zabbix监控nginx_status_第1张图片

1.创建获取nginxstatus参数数据传送到server端脚本

 
  
  1. [root@Zabbix_Server script]# cat >> /usr/local/sbin/nginx_status.sh << EOF

  2. #!/bin/bash

  3. # Script to fetch nginx statuses for tribily monitoring systems

  4. # License: GPLv4

  5. # Set Variables

  6. BKUP_DATE=`/bin/date +%Y%m%d`

  7. LOG="/etc/zabbix/nginx_status.log"

  8. #HOST=`/sbin/ifconfig eth0 | sed -n '/inet /{s/.*addr://;s/ .*//;p}'`

  9. HOST=`/sbin/ifconfig eth0 |grep "inet addr" |awk -F[:" "] '{print $13}'`

  10. PORT="80"

  11. # Functions to return nginx stats

  12. function active {

  13.    /usr/bin/curl "http://$HOST:$PORT/status" 2>/dev/null| grep 'Active' | awk '{print $NF}'

  14.    }      

  15. function reading {

  16.    /usr/bin/curl "http://$HOST:$PORT/status" 2>/dev/null| grep 'Reading' | awk '{print $2}'

  17.    }      

  18. function writing {

  19.    /usr/bin/curl "http://$HOST:$PORT/status" 2>/dev/null| grep 'Writing' | awk '{print $4}'

  20.    }      

  21. function waiting {

  22.    /usr/bin/curl "http://$HOST:$PORT/status" 2>/dev/null| grep 'Waiting' | awk '{print $6}'

  23.    }      

  24. function accepts {

  25.    /usr/bin/curl "http://$HOST:$PORT/status" 2>/dev/null| awk NR==3 | awk '{print $1}'

  26.    }      

  27. function handled {

  28.    /usr/bin/curl "http://$HOST:$PORT/status" 2>/dev/null| awk NR==3 | awk '{print $2}'

  29.    }      

  30. function requests {

  31.    /usr/bin/curl "http://$HOST:$PORT/status" 2>/dev/null| awk NR==3 | awk '{print $3}'

  32.    }

  33. # Run the requested function

  34. $1

  35. EOF

关于对于这个脚本的解释:

这个脚本当中定义了一些状态项名称的函数,函数的功能是通过curl这个工具抓取到nginx web页面的状态数据。

2.添加agent客户端key值,以便让zabbix server获取状态数据


 
  
  1. [root@Zabbix_Server script]# cat >>/etc/zabbix/zabbix_agentd.conf<< EOF

  2. #nginx_status_key

  3. UserParameter=nginx.accepts,/usr/local/sbin/nginx_status.sh accepts

  4. UserParameter=nginx.handled,/usr/local/sbin/nginx_status.sh handled

  5. UserParameter=nginx.requests,/usr/local/sbin/nginx_status.sh requests

  6. UserParameter=nginx.connections.active,/usr/local/sbin/nginx_status.sh active

  7. UserParameter=nginx.connections.reading,/usr/local/sbin/nginx_status.sh reading

  8. UserParameter=nginx.connections.writing,/usr/local/sbin/nginx_status.sh writing

  9. UserParameter=nginx.connections.waiting,/usr/local/sbin/nginx_status.sh waitin

  10. EOF

在此配置文件中,定义了几个UserParameter,这些UserParameter的值就是对应的key,这在我们后面添加Items项当中的 Key 字段要对应,如下图标记处显示:

【APP】zabbix监控nginx_status_第2张图片

3.我们可以通过在 zabbix server 端的shell命令行来进行测试:

[root@Zabbix_Server script]# zabbix_get -s 172.28.2.151 -p 10050 -k "nginx.connections.active"

1

如果能获取到数据说明配置成功!

4.接下来就是在监控端对nginx客户端进行配置

基本流程:

创建主机--->创建Items--->创建Graphs--->加入到Screens