在被监控端安装一个nginx 这里是yum安装
yum -y install nginx
yum -y install zabbix_agent
1)在浏览器中输入 "域名/nginx_status" 就会显示nginx上次启动以来工作状态的统计的结果。
如下图:
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.conf
的server
段中添加:
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服务
这里是导入一个zabbx监控nginx的模板