zabbix添加php监控

简介:

本文主要是针对与添加php-fpm方法,生产环境有个坑,填下,初始环境不是我做的,我是来填坑的,

j_0065.gif

以源码安装为例:

目录环境:

/usr/local/php/etc/php-fpm.conf

/usr/local/nginx/conf/nginx.conf

------------------------------------------------------------


一、开始按照书上配的,发现没有sock文件,当然访问就报错了

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
server {
             listen 127.0.0.1:80;
             server_name 127.0.0.1;
             location  /nginx_status  {
                 stub_status on;
                 access_log off;
                 allow 127.0.0.1;
                 deny all;
             }
             location ~ ^/(phpfpm_status)$ {
                 include fastcgi_params;
                 fastcgi_pass  unix: /tmp/php-cgi .sock;
                 fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
             }
}
# curl 127.0.0.1/phpfpm_status

502报错

查看了一下nginx的error日志:

1
*100011 connect() to unix: /tmp/php-fcgi .sock failed (2: No such  file  or directory)  while  connecting to upstream, client: 127.0.0.1, server: 127.0.0.1, request:  "GET /phpfpm_status HTTP/1.1" , upstream:  "fastcgi://unix:/tmp/php-fcgi.sock:" , host:  "127.0.0.1"

二、查了查网上发现:

其中fastcgi_pass为配置nginx与php-fpm的交互路径,一般有两种方式

1
2
sock方式:fastcgi_pass    unix: /tmp/php-cgi .sock;
http方式:fastcgi_pass    127.0.0.1:9000;

任选其中一种即可,但必须和php-fpm的配置一致。

三、解决方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
重启nginx
# vim /usr/local/nginx/conf/nginx.conf
server {
             listen 127.0.0.1:80;
             server_name 127.0.0.1;
             location  /nginx_status  {
                 stub_status on;
                 access_log off;
                 allow 127.0.0.1;
                 deny all;
             }
             location ~ ^/(phpfpm_status)$ {
                 include fastcgi_params;
                 fastcgi_pass 127.0.0.1:9000;
                 fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
             }
}
# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf -s reload
# curl 127.0.0.1/phpfpm_status
 
pool:                 www
process manager:      dynamic
start  time :           20 /Jun/2017 :17:22:19 +0800
start since:          2245
accepted conn:        40
listen queue:         0
max listen queue:     0
listen queue len:     128
idle processes:       1
active processes:     1
total processes:      2
max active processes: 2
max children reached: 0
slow requests:        0
可以了
php-fpm status状态值详解
pool:fpm池子名称,大多数为www
process manager:进程管理方式,值:static,dynamic or ondemand
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,那说明你的最大进程数量太小了,需要设置大点

四、监控脚本

(1)shell脚本,此脚本是抄袭的

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#!/bin/bash
source  /etc/bashrc  > /dev/null  2>&1
source  /etc/profile  > /dev/null  2>&1
LOG= /var/log/zabbix/phpfpmstatus .log
curl -s http: //localhost/phpfpmstatus  >$LOG
pool(){
     awk  '/pool/ {print $NF}'  $LOG
}
process_manager(){
     awk  '/process manager/ {print $NF}'  $LOG
}
start_since(){
     awk  '/start since:/ {print $NF}'  $LOG
}
accepted_conn(){
     awk  '/accepted conn:/ {print $NF}'  $LOG
}
listen_queue(){
     awk  '/^(listen queue:)/ {print $NF}'  $LOG
}
max_listen_queue(){
     awk  '/max listen queue:/ {print $NF}'  $LOG
}
listen_queue_len(){
     awk  '/listen queue len:/ {print $NF}'  $LOG
}
idle_processes(){
     awk  '/idle processes:/ {print $NF}'  $LOG
}
active_processes(){
     awk  '/^(active processes:)/ {print $NF}'  $LOG
}
total_processes(){
     awk  '/total processes:/ {print $NF}'  $LOG
}
max_active_processes(){
     awk  '/max active processes:/ {print $NF}'  $LOG
}
max_children_reached(){
     awk  '/max children reached:/ {print $NF}'  $LOG
}
case  "$1"  in
pool)
      pool
      ;;
process_manager)
      process_manager
      ;;
start_since)
      start_since
      ;;
accepted_conn)
      accepted_conn
      ;;
listen_queue)
      listen_queue
      ;;
max_listen_queue)
      max_listen_queue
      ;;
listen_queue_len)
      listen_queue_len
      ;;
idle_processes)
      idle_processes
      ;;
active_processes)
      active_processes
      ;;
total_processes)
      total_processes
      ;;
max_active_processes)
      max_active_processes
      ;;
max_children_reached)
      max_children_reached
      ;;
*)
echo  "Usage: $1 {pool|process_manager|start_since|accepted_conn|listen_queue|max_listen_queue|listen_queue_len|idle_processes|active_processes|total_processes|max_active_processes|max_children_reached}"
esac

(2)python脚本,这个是自己写的,写的不好,还望海涵。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#!/usr/bin/env python
#__*__coding:utf8__*__
import  urllib2,sys,os
def  Php_status():
     php_status_dirt  =  {}
     request_status_list  =  []
     php_status_list  =  [ "pool" , "process_manager" , "start_since" , "accepted_conn" , "listen_queue" , "max_listen_queue" , "listen_queue_len" , "idle_processes" , "active_processes" , "total_processes" , "max_active_processes" , "max_children_reached" ]
     php_url  =  'http://127.0.0.1/phpfpm_status'
     req  =  urllib2.Request(php_url)
     response  =  urllib2.urlopen(req)
     request_list  =  response.read().split()
     # request_status_list=[request_list[1],request_list[4],request_list[11],request_list[14],request_list[17],request_list[21],request_list[25],request_list[28],request_list[31],request_list[34],request_list[38],request_list[42],request_list[45]]
     #以下数字位置都是上面截出来的,为了美观,将位置作为了列表,在用位置列表定位request_list中的值['www', 'dynamic', '57795', '5424', '0', '0', '128', '2', '1', '3', '3', '0', '0', 'www', 'dynamic', '57795', '5424', '0', '0', '128', '2', '1', '3', '3', '0', '0'],并追加到request_status_list里面
     #position--->request_list--->(request_status_list+php_status_list)--->php_status_dirt
     position = [ 1 , 4 , 11 , 14 , 17 , 21 , 25 , 28 , 31 , 34 , 38 , 42 , 45 ]
     for  in  position:
         request_status_list.append(request_list[i])
     for  in  range ( len (php_status_list)):
         php_status_dirt[php_status_list[i]]  =  request_status_list[i]
     if  len (sys.argv)  is  not  2  or  str (sys.argv[ 1 ])  not  in  php_status_dirt.keys():
         print  "Usage: php_stauts.py $1 {pool|process_manager|start_since|accepted_conn|listen_queue|max_listen_queue|listen_queue_len|idle_processes|active_processes|total_processes|max_active_processes|max_children_reached}"
         exit( 1 )
     else :
         print  php_status_dirt[ str (sys.argv[ 1 ])]
if  __name__  = =  '__main__' :
     try :
         Php_status()
     except  urllib2.URLError,e:
         print  "%s,there may be something wrong with php!"  % e

五、配置监控扩展

被监控主机端,zabbix_agentd.conf文件中添加上这个:

1
UserParameter=phpfpm[*], /etc/zabbix/scripts/phpfpm_status .py $1

或者

1
UserParameter=phpfpm[*], /etc/zabbix/scripts/phpfpm_status .sh $1

六、将脚本放置在/etc/zabbix/scripts/目录下

1
chmod  +x phpfpm.py

七、测试

1
2
3
4
[root@zabbix_server-12-155 ~] # zabbix_get -s 10.1.12.177 -k phpfpm[s]
Usage: php_stauts.py $1 {pool|process_manager|start_since|accepted_conn|listen_queue|max_listen_queue|listen_queue_len|idle_processes|active_processes|total_processes|max_active_processes|max_children_reached}
[root@zabbix_server-12-155 ~] # zabbix_get -s 10.1.12.177 -k phpfpm[pool]
www

接下来就是添加监控项了,模版我是在这下的https://www.ttlsa.com/zabbix/zabbix-monitor-php-fpm-status/










本文转自 wangpengtai  51CTO博客,原文链接:http://blog.51cto.com/wangpengtai/1940563,如需转载请自行联系原作者
目录
相关文章
|
4月前
|
JSON 监控 PHP
企业局域网监控软件的扩展性设计:PHP插件开发指南
在企业网络环境中,对局域网进行监控是至关重要的。为了满足不同企业的需求,我们需要一种灵活可扩展的监控软件,能够根据具体情况进行定制和扩展。本文将介绍如何利用PHP插件来实现企业局域网监控软件的扩展性设计,并提供一些代码示例,帮助读者更好地理解和应用这一技术。
192 2
|
4月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
4月前
|
数据采集 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
219 4
|
22天前
|
监控 安全 Linux
在Linux中,zabbix如何监控脑裂?
在Linux中,zabbix如何监控脑裂?
|
11天前
|
监控 关系型数据库 MySQL
zabbix agent集成percona监控MySQL的插件实战案例
这篇文章是关于如何使用Percona监控插件集成Zabbix agent来监控MySQL的实战案例。
26 2
zabbix agent集成percona监控MySQL的插件实战案例
|
1月前
|
SQL 监控 分布式数据库
【解锁数据库监控的神秘力量!】OceanBase社区版与Zabbix的完美邂逅 —— 揭秘分布式数据库监控的终极奥秘!
【8月更文挑战第7天】随着OceanBase社区版的普及,企业广泛采用这一高性能、高可用的分布式数据库。为保障系统稳定,使用成熟的Zabbix监控工具对其进行全方位监控至关重要。本文通过实例介绍如何在Zabbix中配置监控OceanBase的方法,包括创建监控模板、添加监控项(如TPS)、设置触发器及图形展示,并提供示例脚本帮助快速上手。通过这些步骤,可以有效监控OceanBase状态,确保业务连续性。
54 0
|
3月前
|
SQL 监控 安全
代码审计-PHP原生开发篇&SQL注入&数据库监控&正则搜索&文件定位&静态分析
代码审计-PHP原生开发篇&SQL注入&数据库监控&正则搜索&文件定位&静态分析
|
3月前
|
监控 数据库 Docker
Zabbix监控神通数据库教程
**摘要:** 本文介绍了如何使用Docker安装和配置神舟通用数据库,并利用Zabbix进行监控。首先,通过Docker安装数据库镜像,启动容器并映射端口。接着,使用默认凭证连接数据库并验证安装。然后,将数据库的Python模块和库文件复制到主机,并安装Python3.5及相应模块,创建外部检查脚本以实现Zabbix的监控功能。示例展示了查询数据库版本的监控指标配置。最后,提到了监控结果的界面展示,并邀请读者探索更多Zabbix监控技巧。
50 0
Zabbix监控神通数据库教程
|
2月前
|
监控 关系型数据库 应用服务中间件
Linux zabbix监控 软件的安装
Linux zabbix监控 软件的安装
|
4月前
|
Prometheus 监控 Kubernetes
Kubernetes 集群的监控与日志管理实践深入理解PHP的命名空间与自动加载机制
【5月更文挑战第30天】 在容器化和微服务架构日益普及的背景下,Kubernetes 已成为众多企业的首选容器编排工具。然而,随之而来的挑战是集群的监控与日志管理。本文将深入探讨 Kubernetes 集群监控的最佳实践,包括节点资源使用情况、Pods 健康状态以及网络流量分析等关键指标的监控方法。同时,我们也将讨论日志聚合、存储和查询策略,以确保快速定位问题并优化系统性能。文中将介绍常用的开源工具如 Prometheus 和 Fluentd,并分享如何结合这些工具构建高效、可靠的监控和日志管理系统。

推荐镜像

更多