【运维知识进阶篇】zabbix5.0稳定版详解3(监控Nginx+PHP服务状态信息)
admin 阅读: 2024-03-15
后台-插件-广告管理-内容页头部广告(手机) |
这篇文章继续给大家介绍zabbix监控,监控Nginx、PHP等服务,其实非常简单,难点在于如何去取这个值,包括监控业务,难点在于思路是否清晰,思维是否活跃,如何去进行判断是否有这个业务,并且业务正常运行。
目录
监控Nginx服务状态信息
一、开启Nginx状态模块
二、配置监控项
三、创建模板
四、用默认键值添加Nginx-status端口监控项,并配置触发器
五、基于模板创建图形
六、模板创建完毕后关联被监控的主机
监控PHP服务状态信息
一、安装PHP服务配置
二、配置PHP状态信息
三、修改Nginx配置文件
四、自定义监控项
五、创建自定义PHP模板(监控项+触发器+图形)
六、关联模板到监控主机
七、测试PHP访问
监控Nginx服务状态信息
通过Nginx监控模块,监控Nginx的7种状态
- Nginx 的状态模块展示了七种不同的状态(四种计数器和三种状态)。以下是这七种状态的含义:
- 1. active:当前 Nginx 正在处理的连接数,包括等待请求处理或正在响应请求的连接数。
- 2. accepts:Nginx 启动后已经接受的连接总数。
- 3. handled:Nginx 工作进程已成功处理的连接总数。与 accepts 计数器不同,此计数器可能会多个小于 accepts 数量,在某些情况下,客户端可能已经断开了连接而无法正常处理。
- 4. requests:已经接收到、处理并响应的请求数量,该值通常应与 handled 值相等。
- 5. reading:当前正在读取客户端请求头部字段的连接数。
- 6. writing:当前正在向客户端发送响应数据的连接数。
- 7. waiting:空闲 keep-alive 连接,既没有读也没有写。可以处理下一个请求的连接。
- 通过理解这些状态可以帮助我们了解 Nginx 正在处理哪些连接,并且在调试和优化性能时非常有用。 当 active 连接数随着来自客户端的请求增加而增加时,可能需要考虑优化配置以确保足够的性能水平和稳定性。
一、开启Nginx状态模块
- [root@Web01 ~]# cat /etc/nginx/conf.d/status.conf
- server {
- listen 88;
- location /nginx_status {
- stub_status;
- }
- }
- [root@Web01 ~]# systemctl restart nginx
二、配置监控项
- [root@Web01 ~]# curl -s 127.0.0.1:88/nginx_status
- Active connections: 1
- server accepts handled requests
- 4 4 3
- Reading: 0 Writing: 1 Waiting: 0
用awk以此取值,并设置为key
- [root@Web01 ~]# cat /etc/zabbix/zabbix_agentd.d/nginx.conf
- UserParameter=nginx.connections,curl -s 127.0.0.1:88/nginx_status|awk 'NR==1{print $NF}'
- UserParameter=nginx.accepts,curl -s 127.0.0.1:88/nginx_status|awk 'NR==3{print $1}'
- UserParameter=nginx.handled,curl -s 127.0.0.1:88/nginx_status|awk 'NR==3{print $2}'
- UserParameter=nginx.requests,curl -s 127.0.0.1:88/nginx_status|awk 'NR==3{print $3}'
- UserParameter=nginx.Reading,curl -s 127.0.0.1:88/nginx_status|awk 'NR==4{print $2}'
- UserParameter=nginx.Writing,curl -s 127.0.0.1:88/nginx_status|awk 'NR==4{print $4}'
- UserParameter=nginx.Waiting,curl -s 127.0.0.1:88/nginx_status|awk 'NR==4{print $6}'
- [root@Web01 ~]# systemctl restart zabbix-agent.service
测试取值
- [root@Zabbix ~]# zabbix_get -s 172.16.1.7 -k nginx.connections
- 1
三、创建模板
基于模板创建监控项,也可以先添加监控项在复制到模板
其他六项也同理,不再截图
四、用默认键值添加Nginx-status端口监控项,并配置触发器
配置触发器
五、基于模板创建图形
六、模板创建完毕后关联被监控的主机
Web02同理
监控PHP服务状态信息
一、安装PHP服务配置
上传PHP RPM包,安装
二、配置PHP状态信息
- [root@Web01 ~]# cat /etc/php-fpm.d/www.conf|grep pm.status_path
- pm.status_path = /status
- [root@Web01 ~]# systemctl restart php-fpm
三、修改Nginx配置文件
- [root@Web01 ~]# cat /etc/nginx/conf.d/status.conf
- server {
- listen 88;
- location /nginx_status {
- stub_status;
- }
- location /status {
- fastcgi_pass 127.0.0.1:9000;
- fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
- include fastcgi_params;
- }
- }
- [root@Web01 ~]# systemctl restart nginx
- [root@Web01 ~]# curl 127.0.0.1:88/status
- pool: www #pool的名称
- process manager: dynamic #进程管理方式,现今大多都为dynamic,不要使用static
- start time: 16/May/2023:21:30:31 +0800 #php-fpm上次启动的时间
- start since: 133 #php-fpm已运行了多少秒
- accepted conn: 1 #pool接受到的请求数
- listen queue: 0 #处于等待状态中的连接数,如果不为0,需要增加php-fpm进程数
- max listen queue: 0 #从php-fpm启动到现在处于等待连接的最大数量
- listen queue len: 128 #处于等待连接队列的套接字大小
- idle processes: 4 #处于空闲状态的进程数
- active processes: 1 #处于活动状态的进程数
- total processes: 5 #进程总数
- max active processes: 1 #从php-fpm启动到现在最多有几个进程处于活动状态
- max children reached: 0 #当php-fpm试图启动更多的children进程时,却达到了进程数的限制,达到一次记录一次,如果不为0,需要增加php-fpm pool进程的最大数
- slow requests: 0 #当启用了php-fpm slow-log功能时,如果出现了php-fpm慢请求,这个计数器会增加,一般不当的mysql查询会触发这个值
四、自定义监控项
- [root@Web01 ~]# cat /etc/zabbix/zabbix_agentd.d/php.conf
- UserParameter=fpm.accepted,curl -s 127.0.0.1:88/status|grep accepted|awk '{print $NF}'
- UserParameter=fpm.idle,curl -s 127.0.0.1:88/status|grep idle|awk '{print $NF}'
- UserParameter=fpm.active,curl -s 127.0.0.1:88/status|grep ^active|awk '{print $NF}'
- UserParameter=fpm.total,curl -s 127.0.0.1:88/status|grep total|awk '{print $NF}'
- UserParameter=fpm.children,curl -s 127.0.0.1:88/status|grep children|awk '{print $NF}'
- [root@Web01 ~]# systemctl restart zabbix-agent
- [root@Web01 ~]# zabbix_agentd -p | grep ^fpm #客户端查看能否正常获取值
- zabbix_agentd [7902]: Warning: EnableRemoteCommands parameter is deprecated, use AllowKey=system.run[*] or DenyKey=system.run[*] instead
- fpm.accepted [t|56]
- fpm.idle [t|5]
- fpm.active [t|1]
- fpm.total [t|6]
- fpm.children [t|0]
- [root@Zabbix ~]# zabbix_get -s 172.16.1.7 -k fpm.accepted #服务端查看能否正常获取客户端的值
- 62
五、创建自定义PHP模板(监控项+触发器+图形)
1)基于模板添加监控项
依次添加其他配置项,除自定义的外再多添加个端口监控,zabbix自带的
2)基于模板配置触发器
3分钟之内受到限制次数的最大数等于5则报警
3)基于模板配置图形
六、关联模板到监控主机
七、测试PHP访问
[root@Web02 ~]# for i in `seq 100`;do ab -n2000 -c20 127.0.0.1:88/status;done发现fpm连接数上涨
我是koten,10年运维经验,持续分享运维干货,感谢大家的阅读和关注!
声明
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。
在线投稿:投稿 站长QQ:1888636
后台-插件-广告管理-内容页尾部广告(手机) |