文档章节

zabbix3.2学习笔记(六):自定义监控nginx+php-fpm status

e
 echo132455
发布于 2017/08/29 14:32
字数 1039
阅读 21
收藏 0

zabbix自带了一些模版,可根据需要修改对应监控项的阈值;可是像nginx/ph-fpm/redis/mysql等一些应用还需要我们自定义监控项、用脚本在客户端取值。下面简单监控nginx和php-fpm的状态:二者本身自带status参数,只需开启即可。

1,开启status

vi /etc/php-fpm.conf 尾部添加一行
pm.status_path = /php-fpm_status

cd /etc/nginc/conf.d/
vi nginxphp_status.conf
server {

listen 40080;
allow 127.0.0.1;
deny all;
access_log off;
location /php-fpm_status {
     fastcgi_pass 127.0.0.1:9000;
      include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
}

location /nginx_status {
      stub_status on;
}
}

service php-fpm restart
service nginx restart

curl -s http://127.0.0.1:40080/nginx_status
Active connections: 1
server accepts handled requests
6 6 6
Reading: 0 Writing: 1 Waiting: 0

nginx status详解
active connections – 活跃的连接数
server accepts handled requests — 总共处理了6个连接 , 成功创建6次握手, 总共处理了6个请求
reading — 读取客户端的连接数
writing — 响应数据到客户端的数量
waiting — 开启 keep-alive 的情况下,这个值等于 active – (reading+writing), 意思就是 Nginx 已经处理完正在等候下一次请求指令的驻留连接。所以,在访问效率高,请求很快被处理完毕的情况下,Waiting数比较多是正常的.如果reading +writing数较多,则说明并发访问量非常大,正在处理过程中。

curl -s http://127.0.0.1:40080/php-fpm_status
pool: www
process manager: dynamic
start time: 17/Aug/2017:17:09:32 +0800
start since: 64
accepted conn: 2
listen queue: 0
max listen queue: 0
listen queue len: 128
idle processes: 4
active processes: 1
total processes: 5
max active processes: 1
max children reached: 0
slow requests: 0

php-fpm status详解
pool – fpm池子名称,大多数为www 
process manager – 进程管理方式,值:static, dynamic or ondemand. dynamic 
start time – 启动日期,如果reload了php-fpm,时间会更新 
start since – 运行时长 
accepted conn – 当前池子接受的请求数 
listen queue – 请求等待队列,如果这个值不为0,那么要增加FPM的进程数量 
max listen queue – 请求等待队列最高的数量 
listen queue len – socket等待队列长度 
idle processes – 空闲进程数量 
active processes – 活跃进程数量 
total processes – 总进程数量 
max active processes – 最大的活跃进程数量(FPM启动开始算) 
max children reached - 大道进程最大数量限制的次数,如果这个数量不为0,那说明你的最大进程数量大小了,需改大一点。 
php-fpm状态页可以通过带参数实现个性化,可以带参数json、xml、html并且前面三个参数可以分别和full做一个组合。
json格式:http://127.0.0.1:40080/php-status?json
xml格式: http://127.0.0.1:40080/php-status?xml
html 格式: http://127.0.0.1:40080/php-status?html 
full格式: http://127.0.0.1:40080/php-status?ful

2,在zabbix agent端新建shell脚本来取值
cd /etc/zabbix/zabbix_agentd.d
vi php-fpm_status.sh

#!/bin/bash

idle(){
        wget --quiet -O - http://127.0.0.1:40080/php-fpm_status?auto |grep "idle processes" |awk '{print$3}'
}

total(){
        wget --quiet -O - http://127.0.0.1:40080/php-fpm_status?auto |grep "total processes" |awk '{print$3}'
}

active(){
        wget --quiet -O - http://127.0.0.1:40080/php-fpm_status?auto |grep "active" |awk '{print$3}'|grep -v "process"
}

mactive(){

        wget --quiet -O - http://127.0.0.1:40080/php-fpm_status?auto |grep "max active processes:" |awk '{print$4}'
}

listenqueuelen(){
        wget --quiet -O - http://127.0.0.1:40080/php-fpm_status?auto |grep "listen queue len" |awk '{print$4}'
}

listenqueue(){
        wget --quiet -O - http://127.0.0.1:40080/php-fpm_status?auto |grep "listen queue:"|grep -vE "len|max"|awk '{print$3}'
}

since(){
        wget --quiet -O - http://127.0.0.1:40080/php-fpm_status?auto |grep "start since: " |awk '{print$3}'
}

conn(){
        wget --quiet -O - http://127.0.0.1:40080/php-fpm_status?auto |grep "accepted conn" |awk '{print$3}'
}
$1

vi nginx_status.sh

#!/bin/bash

Active(){
        wget --quiet -O - http://localhost:40080/nginx_status?auto |awk 'NR==1 {print$3}'
}
Reading(){
        wget --quiet -O - http://localhost:40080/nginx_status?auto |awk 'NR==4 {print$2}'
}
Writing(){
        wget --quiet -O - http://localhost:40080/nginx_status?auto |awk 'NR==4 {print$4}'
}
Waiting(){
        wget --quiet -O - http://localhost:40080/nginx_status?auto |awk 'NR==4 {print$6}'
}
$1
3,修改/etc/zabbix/zabbix_agentd.conf添加一下内容
UnsafeUserParameters=1 

UserParameter=idle.processe,/etc/zabbix/zabbix_agentd.d/php-fpm_status.sh idle
UserParameter=total.processes,/etc/zabbix/zabbix_agentd.d/php-fpm_status.sh total
UserParameter=active.processes,/etc/zabbix/zabbix_agentd.d/php-fpm_status.sh active
UserParameter=max.active.processes,/etc/zabbix/zabbix_agentd.d/php-fpm_status.sh mactive
UserParameter=listen.queue.len,/etc/zabbix/zabbix_agentd.d/php-fpm_status.sh listenqueuelen
UserParameter=listen.queue,/etc/zabbix/zabbix_agentd.d/php-fpm_status.sh listenqueue
UserParameter=start.since,/etc/zabbix/zabbix_agentd.d/php-fpm_status.sh since
UserParameter=accepted.conn,/etc/zabbix/zabbix_agentd.d/php-fpm_status.sh conn

UserParameter=Active,/etc/zabbix/zabbix_agentd.d/nginx_status.sh Active
UserParameter=Reading,/etc/zabbix/zabbix_agentd.d/nginx_status.sh Reading
UserParameter=Writing,/etc/zabbix/zabbix_agentd.d/nginx_status.sh Writing
UserParameter=Waiting,/etc/zabbix/zabbix_agentd.d/nginx_status.sh Waiting

service zabbix-agent restart

4,在zabbix web端导入以下模版
http://pan.baidu.com/s/1bp3wJYf

将主机关联以上模版,随后在最新数据里查看是否收集到监控值

github上搜索zabbix会看到很多开源的监控模版,挑你需要的试试吧

本文转载自:https://my.oschina.net/u/2404183/blog/1512475

共有 人打赏支持
e
粉丝 0
博文 7
码字总数 506
作品 0
私信 提问
Nginx+PHP-FPM打开status

启用 php-fpm 状态功能 2. nginx配置 在要监控的主机里添加上 locaction. 3. 重启 nginx 和php-fpm 4. 打开 status 页面 在浏览器里打开或者用 curl 命令打开都可以 //如果你的 nginx 默认端...

zcqshine
2015/11/10
0
9
zabbix监控nginx和php、memcached(discuz)

创建zabbixagentd的子配置文件 在/etc/zabbix/zabbixagentd.d/中创建关联nginx status和php-fpm status的子配置文件,创建一个,或者在已有的某配置文件中增加也可以,我这里分别为它们创建配...

wsw26
06/26
0
0
zabbix监控nginx和php、memcached(discuz)

创建zabbixagentd的子配置文件 在/etc/zabbix/zabbixagentd.d/中创建关联nginx status和php-fpm status的子配置文件,创建一个,或者在已有的某配置文件中增加也可以,我这里分别为它们创建配...

技术小胖子
2017/11/07
0
0
zabbix监控nginx和fpm(网站并发数)自定义key

监控nginx,主要讲解监控并发数: 1: nginx编译参数: --prefix=/usr/local/nginx --with-httpstubstatus_module zabbix编译参数的查看: /usr/local/nginx/sbin/nginx -V nginx version: ng......

拎壶冲冲冲
08/21
0
0
Linux下,400-500并发,用Apache+PHP_MOD还是Nginx+PHP-fpm比较靠谱?

一直使用Ubuntu自带的LAMP做比较小的项目,最近遇到对并发要求比较高的,在考虑是否用Nginx+PHP-fpm,由于没有详细测试过,所以征求下过来人的意见。另外Nginx+PHP-fpm应该怎么设置性能方面的...

BossKiller
2014/03/16
2.4K
5

没有更多内容

加载失败,请刷新页面

加载更多

java框架学习日志-5(常见的依赖注入)

依赖注入(dependency injection) 之前提到控制反转(Inversion of Control)也叫依赖注入,它们其实是一个东西,只是看的角度不同,这章详细说一下依赖注入。 依赖——指bean对象创建依赖于...

白话
22分钟前
1
0
《读书是教师最好的修行》读后感优秀范文2200字

《读书是教师最好的修行》读后感优秀范文2200字: 作者:吴淑英;《读书是教师最好的修行》一书,收录了作者对50本经典书籍阅读后阐发的感受。作者10年来坚持每周阅读一本书,并写一篇读后感...

原创小博客
24分钟前
1
0
红外接收器驱动开发

背景:使用系统的红外遥控软件没有反应,然后以为自己接线错误,反复测试,结果烧坏了一个红外接收器,信号主板没有问题。所以自己开发了一个红外接收器的python驱动。接线参见https://my.os...

mbzhong
今天
2
0
ActiveMQ消息传送机制以及ACK机制详解

AcitveMQ是作为一种消息存储和分发组件,涉及到client与broker端数据交互的方方面面,它不仅要担保消息的存储安全性,还要提供额外的手段来确保消息的分发是可靠的。 一. ActiveMQ消息传送机...

watermelon11
今天
1
0
HashTable和Vector为什么逐渐被废弃

HashTable,不允许键值为null,还一个就是put方法使用sychronized方法进行线程同步,单线程无需同步,多线程可用concurren包的类型。 如编程思想里面说的作为工具类,封闭性做的不好没有一个...

noob_chr
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部