Zabbix_nginx监控

在被监控端安装一个nginx 这里是yum安装

yum -y install nginx 
yum -y install zabbix_agent

1)在浏览器中输入 "域名/nginx_status" 就会显示nginx上次启动以来工作状态的统计的结果。
如下图:


image.png

2)返回各数据项说明:
Active connections: 当前nginx正在处理的活动连接数.
Server accepts handled requests request_time: nginx总共处理了13057 个连接,成功创建13057 握手(证明中间没有失败的),总共处理了11634 个请求,总共请求时间2230854。
Reading: nginx读取到客户端的Header信息数.
Writing: nginx返回给客户端的Header信息数.
Waiting: 开启keep-alive的情况下,这个值等于 active – (reading + writing),意思就是nginx已经处理完成,正在等候下一次请求指令的驻留连接。

所以,在访问效率高,请求很快被处理完毕的情况下,Waiting数比较多是正常的.
如果reading +writing数较多,则说明并发访问量非常大,正在处理过程中

nginx的ngx_http_stub_status_module模块提供了基本的nginx状态信息,源码安装的话需要加上–with-http_stub_status_module编译参数,或者如果是epel源yum安装的话,已经默认启用该模块。在nginx.confserver段中添加:

 location /stub_status {
             stub_status on;
             access_log off;
             allow 127.0.0.1;
             deny all;
       }

重启nginx服务

/usr/sbin/nginx -s reload

访问nginx

[root@671ff69acf99 nginx]# curl http://127.0.0.1/stub_status
Active connections: 1          当前[活动]的连接数量。
server accepts handled requests
 9421 9421 9421 
Reading: 0 Writing: 1 Waiting: 0 

--------------------------------------------------------------
Accepts:已经接受客户端的连接总数量。

Handled:已经处理客户端的连接总数量。

(一般与accepts一致,除非服务器限制了连接数量)。

Requests:客户端发送的请求数量。

服务器与客户端之间的操作

Reading:当前服务器正在读取客户端请求头的数量。

Writing:当前服务器正在写响应信息的数量。

Waiting:当前多少客户端在等待服务器的响应

编写脚本 这里我和nginx配置文件在一个目录下 一会自定义键值对方便找到
shell脚本

#! /bin/bash

HOST="127.0.0.1"

PORT="80"

case $1 in
  ping)

     /sbin/pidof nginx |wc -l ;;

  active)

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

  reading)

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

  writing)

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

  waiting)

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

  accepts)

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

  handled)

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

  requests)

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

  *)

    echo 'ping|active|reading|writing|waiting|accepts|handled|requests' ;;

esac

这里使用的ping是要监测nginx服务是否正常需要下个包安装pidof

yum -y install sysvinit-tools-2.88-14.dsf.el7.x86_64

python脚本(python3 需要提前安装 yum就可以了)

import sys
import requests
import re

help_msg = """
usage:
     {} [active,accepts,handled,requests,reading,writing,waiting]
""".format(sys.argv[0])


def usage():
    print(help_msg)


if len(sys.argv) < 2:
    usage()
try:
    r = requests.get(url='http://172.17.0.6:80/stub_status/')
    isAlive = r.status_code

    data = {}
    lists = ["active", "accepts", "handled",
            "requests", "reading", "writing", "waiting"]
    num = 0
    for text in re.findall('\d+', r.text):
        data[lists[num]] = text
        num += 1
except Exception as e:
    print(e)
for i in sys.argv[1:]:
    if  not i in lists:
        usage()
        exit()

for i in sys.argv[1:]:
    print(data[i])

编写自定义键值 /etc/zabbix/zabbix_agentd.d/

### nginx
UserParameter=nginx.status[*], sh /opt/nginx.sh $1
UserParameter=nginx.statuspy[*], python3 /opt/nginx.py $1

将zabbix_agent进程kill掉重启这个服务、让agent来读取这个配置文件

接下来就可以使用web端进行看结果了

这里我新建了一个主机来专门监测nginx服务

image

这里是导入一个zabbx监控nginx的模板

image

你可能感兴趣的:(Zabbix_nginx监控)