zabbix监控php-status和进程资源使用率

  1. 云栖社区>
  2. 博客>
  3. 正文

zabbix监控php-status和进程资源使用率

技术小阿哥 2017-11-27 14:37:00 浏览603
展开阅读全文

入职以后,领导让我着手zabbix监控的部署和具体的维护。监控php首先就是一个挺重要的事情了。zabbix监控php可以通过php自带的一个status功能来监控,需要在配置文件里面开启,同时在nginx里面配置php status可以访问

1.php-fpm 开启status

1
2
grep pm.status_path /usr/local/php/etc/php-fpm.conf
pm.status_path = /php-fpm-status

默认情况下为/status,当然也可以改成/phpfpm_status等,我这里是改成/php-fpm-status

2.nginx配置

1
2
3
4
5
6
7
8
9
server {
        listen 80;
        server_name 127.0.0.1;
        location /phpfpm_status {
                fastcgi_pass  127.0.0.1:9000;
                include fastcgi_params;
                fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
        }
}

3.php status详解

1
2
3
4
5
6
7
8
9
10
11
12
13
14
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,那说明你的最大进程数量太小了,请改大一点。
slow requests – 启用了php-fpm slow-log,缓慢请求的数量

4.添加zabbix_agent 配置

1
2
3
4
5
6
[root@localhost zabbix_agentd.conf.d]# cat check_php_status.conf 
UserParameter=php-fpm.status[*],/etc/zabbix/alertscripts/php_status.sh  $1
UserParameter=php_status,ps -ef | grep php-fpm | awk '{ print $9}' |  grep master  | wc -l
UserParameter=process.php.memory,/home/hckjS213/zabbix/etc/script/processstatus.sh phpmem
UserParameter=process.php.cpu,/home/hckjS213/zabbix/etc/script/processstatus.sh phpcpu
UserParameter=process.php.num,/home/hckjS213/zabbix/etc/script/processstatus.sh phpnum


5.编写php监控脚本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#!/bin/bash
CURL=`which curl`
function idle {
  $CURL "http://127.0.0.1/php-fpm-status" 2>/dev/nullgrep -w '^idle processes:' awk  '{print $3}'
}
function total {
  $CURL "http://127.0.0.1/php-fpm-status" 2>/dev/nullgrep -w '^total processes:' |  awk  '{print $3}'
}
function active {
  $CURL "http://127.0.0.1/php-fpm-status" 2>/dev/nullgrep -w '^active processes:' awk '{print $3}'
}
function listen_queue {
  $CURL "http://127.0.0.1/php-fpm-status" 2>/dev/nullgrep -w "^listen queue:" awk  '{print $3}'
}
function slow_requests {
  output=` $CURL "http://127.0.0.1/php-fpm-status" 2>/dev/nullgrep -w "^slow requests:"awk  '{print $3}'`
if "$output" == "" ];then
echo 0
else
echo $output
fi
   
       }
$1

php进程资源使用率脚本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#!/bin/bash
#chck for php and sphinx used cpu and memory
phpmem(){
    ps aux|grep "php"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$6}; END{print sum}'
}
phpcpu(){
    ps aux|grep "php"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$3}; END{print sum}'
}
phpnum(){
    ps aux|grep "php"|grep -v "grep"|grep -v "processstatus.sh"wc -l
}
case "$1" in
phpmem)
phpmem
;;
phpcpu)
phpcpu
;;
phpnum)
phpnum
;;
*)
echo "Usage: $0 {phpmem|phpcpu|phpnum}"
esac

6.测试

1
2
3
4
[root@Zabbix_server ~]#/usr/local/zabbix/bin/zabbix_get  -s 192.168.50.119 -k php-fpm.status[active]
 1
[root@Zabbix_server ~]# zabbix_get  -s 10.144.164.53 -p 10050 -k process.php.memory   
2070688

wKiom1hSD6ezT2G_AACPEZHIDFc105.png

wKioL1hSD9qBT6MbAACPW9hXpLE213.png



本文转自 shouhou2581314 51CTO博客,原文链接:http://blog.51cto.com/thedream/1882958,如需转载请自行联系原作者

网友评论

登录后评论
0/500
评论
技术小阿哥
+ 关注