zabbix来监控nginx服务
1.nginx服务是否在运行
2.请求数量
1.需要安装nginx服务
yum install epel-release -y
yum install nginx -y
2.启动nginx服务
[root@nginx-mysqldb nginx]# service nginx start
Redirecting to /bin/systemctl start nginx.service
[root@nginx-mysqldb nginx]# lsof -i:80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 40552 root 8u IPv4 316071 0t0 TCP *:http (LISTEN)
nginx 40552 root 9u IPv6 316072 0t0 TCP *:http (LISTEN)
nginx 40553 nginx 8u IPv4 316071 0t0 TCP *:http (LISTEN)
nginx 40553 nginx 9u IPv6 316072 0t0 TCP *:http (LISTEN)
nginx 40555 nginx 8u IPv4 316071 0t0 TCP *:http (LISTEN)
nginx 40555 nginx 9u IPv6 316072 0t0 TCP *:http (LISTEN)
[root@nginx-mysqldb nginx]#
3.在zabbix-agent端的linux服务器上的nginx的主配置文件里添加下面的配置项,开启nginx的统计功能
[root@zabbix-client-1 zabbix_agentd.d]# cat /etc/nginx/nginx.conf
#开启nginx本身的统计功能
location /nginx_status {
stub_status on;
}
4.刷新nginx服务
service nginx restart
5.web方式访问,查看效果
http://192.168.1.xxx/nginx_status
输出效果如下所示:
Active connections: 2
server accepts handled requests
18 18 23
Reading: 0 Writing: 1 Waiting: 1
Active connections Nginx正处理的活动链接数个数;重要
accepts Nginx启动到现在共接受了多少个连接。
handled Nginx启动到现在共处理了多少个连接。
requests Nginx总共处理了请求次数。
Reading Nginx读取到客户端的 Header 信息数。
Writing Nginx返回给客户端的 Header 信息数。
Waiting Nginx已经处理完正在等候下一次请求指令的驻留链接,开启。
Keep-alive的情况下,Waiting这个值等于active-(reading + writing)。
请求丢失数=(握手数-连接数)可以看出,本次状态显示没有丢失请求。
提供以下状态信息:
Active connections
当前活动的客户端连接数,包括Waiting连接数。
accepts
接受的客户端连接总数。
handled
已处理的连接总数。通常,参数值与accepts 除非达到某些资源限制(例如, worker_connections限制)相同。
requests
客户端请求总数。
Reading
nginx正在读取请求标头的当前连接数。
Writing
nginx正在将响应写回到客户端的当前连接数。
Waiting
当前等待请求的空闲客户端连接数
6.zabbix-agent的nginx参数配置文件
[root@zabbix-client-1 zabbix_agentd.d]# cat userparameter_nginx.conf
UserParameter=nginx.status[*],/etc/zabbix/zabbix_agentd.d/nginx.sh $1
[root@zabbix-client-1 zabbix_agentd.d]#
7.在zabbix-agent上的nginx监控脚本
[root@zabbix-client-1 zabbix_agentd.d]# cat nginx.sh
HOST="192.168.1.141"
PORT="80"
function ping {
/sbin/pidof nginx | wc -l
}
function active {
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| grep 'Active' | awk '{print $NF}'
}
function reading {
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| grep 'Reading' | awk '{print $2}'
}
function writing {
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| grep 'Writing' | awk '{print $4}'
}
function waiting {
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| grep 'Waiting' | awk '{print $6}'
}
function accepts {
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk NR==3 | awk '{print $1}'
}
function handled {
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk NR==3 | awk '{print $2}'
}
function requests {
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk NR==3 | awk '{print $3}'
}
case $1 in
active)
active
;;
reading)
reading
;;
writing)
writing
;;
waiting)
waiting
;;
accepts)
accepts
;;
ping)
ping
;;
handled)
handled
;;
requests)
requests
;;
esac
[root@zabbix-client-1 zabbix_agentd.d]#
8.授予nginx.sh可执行权限
[root@nginx-mysqldb zabbix_agentd.d]# chmod +x nginx.sh
9.刷新zabbix-agent服务
[root@nginx-mysqldb zabbix_agentd.d]# service zabbix-agent restart
Redirecting to /bin/systemctl restart zabbix-agent.service
[root@nginx-mysqldb zabbix_agentd.d]#
10.在zabbix-server上测试是否可以采集数据
[root@zabbix-server-1 ~]# zabbix_get -s 192.168.111.133 -p 10050 -k nginx.status[active]
1
[root@zabbix-server-1 ~]# zabbix_get -s 192.168.111.133 -p 10050 -k nginx.status[active]
3
[root@zabbix-server-1 ~]#
11.在zabbix-server上完成下面的操作:
自己创建应用集,添加监控项,然后添加图形,出图
nginx.status[active]
nginx.status[reading]
nginx.status[writing]
nginx.status[waiting]
nginx.status[accepts]
nginx.status[handled]
nginx.status[requests]
创建一个监控项,添加图形
可以将多个监控项添加到一个图形里,这样也比较好,可以对比的看效果
添加一个触发器:
一旦nginx服务down,马上告警
改良版本的nginx_vs.sh的采集数据的脚本
[root@nginx-mysqldb zabbix_agentd.d]# vim nginx_v2.sh
HOST="192.168.1.141"
PORT="80"
case $1 in
active)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| grep 'Active' | awk '{print $NF}'
;;
reading)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| grep 'Reading' | awk '{print $2}'
;;
writing)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| grep 'Writing' | awk '{print $4}'
;;
waiting)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| grep 'Waiting' | awk '{print $6}'
;;
accepts)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk NR==3 | awk '{print $1}'
;;
ping)
/sbin/pidof nginx | wc -w
;;
handled)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk NR==3 | awk '{print $2}'
;;
requests)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk NR==3 | awk '{print $3}'
;;
esac