如何使用zabbix来监控nginx服务
一、实验需求:
1.nginx服务是否在运行
2.请求数量
二、实验操作步骤:
1.需要安装nginx服务
yum install epel-release -y
yum install nginx -y<font color=#999AAA >
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的统计功能,我们需要去监控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.141/nginx_status
输出效果如下所示:
Active connections: 2
server accepts handled requests
18 18 23
Reading: 0 Writing: 1 Waiting: 1
连接数:建立三次握手的次数
请求数:访问网站的次数 --》发request包的次数
Active connections Nginx正处理的活动链接数个数;重要
accepts Nginx启动到现在共接受了多少个连接。
handled Nginx启动到现在共处理了多少个连接。
requests Nginx总共处理了请求次数。
Reading Nginx读取到客户端的 Header 信息数。--》request
Writing Nginx返回给客户端的 Header 信息数。 --》response
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"
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{print $1}'
;;
ping)
/sbin/pidof nginx | wc -w
;;
handled)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk 'NR==3{print $2}'
;;
requests)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk 'NR==3{print $3}'
;;
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]
三.总结归纳
1.先创建一个应用集–》sc-nginx–>创建监控项–》创建图形调用监控项
2.创建一个监控项,添加图形
可以将多个监控项添加到一个图形里,这样也比较好,
可以对比的看效果
3.添加一个触发器:
一旦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{print $1}'
;;
ping)
/sbin/pidof nginx | wc -w
;;
handled)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk 'NR==3{print $2}'
;;
requests)
/usr/bin/curl --insecure "http://$HOST:$PORT/nginx_status/" 2>/dev/null| awk 'NR==3{print $3}'
;;
esac