2019独角兽企业重金招聘Python工程师标准>>>

Zabbix 监控 Nginx

使用 zabbix 监控 nginx,实际上是通过 nginx 自带 status 模块来获取数据的,所以需要配置 ngx_status。

启用 nginx status 模块,需要编译时带上参数 --with-http_sub_module(实际上在编译时带上 --with-http_stub_status_module 这个参数也是可以显示 nginx status的)

配置文件中添加 nginx_status location:

location /nginx_status {stub_status on;access_log off;allow 192.168.0.1;deny all;}

重启 nginx,访问 http://localhost/nginx_status:

Nginx status 监控状态含义

Active connections: 2   #nginx 正处理的活动连接数2个。server accepts handled requests591 591 4936
# nginx启动到现在共处理了 591 个连接 , 成功创建 591 次握手 一般跟第一个一样,差值为请求丢失数, 总共处理了 4936 次请求。Reading: 0      #nginx 读取到客户端的 Header 信息数。Writing: 1      #nginx 返回给客户端的 Header 信息数。Waiting: 1      #开启 keep-alive 的情况下,这个值等于 active - (reading + writing),意思就是 Nginx 已经处理完正在等候下一次请求指令的驻留连接。这个状态信息,从nginx启动算起,包括重载配置文件,也会清零。

Zabbix 客户端配置

由于监控 nginx 状态的 key 在 zabbix agent 中并没有预先定义的key,这时候我们可以通过编写 zabbix 的用户参数的方法来监控我们要求的项目 item。形象一点说 zabbix 代理端配置文件中的 User parameters就相当于通过脚本获取要监控的值,然后把相关的脚本或者命令写入到配置文件中的 User parameter 中然后 zabbix server 读取配置文件中的返回值通过处理前端的方式返回给用户。

配置/etc/zabbix/zabbix_agent.conf 语法:

UserParameter=<key>,<command># 其中 UserParameter 为关键字,key 为用户自定义 key 名字可以随便起,<command> 为我们要运行的命令或者脚本。# 传参数
UserParameter=key[*],command#例
UserParameter=ping[*],echo $1
ping[0]
# return '0'
ping[111]
# return '111'

添加自定义 Userparameter 到配置文件:

# 参数写死
UserParameter=nginx.Accepted-Connections,/usr/local/zabbix-3.0.0/scripts/getNginxInfo.py -h 127.0.0.1 -p 80 -a accepted
UserParameter=nginx.Active-Connections,/usr/local/zabbix-3.0.0/scripts/getNginxInfo.py -h 127.0.0.1 -p 80 -a active
UserParameter=nginx.Handled-Connections,/usr/local/zabbix-3.0.0/scripts/getNginxInfo.py -h 127.0.0.1 -p 80 -a handled
UserParameter=nginx.Reading-Connections,/usr/local/zabbix-3.0.0/scripts/getNginxInfo.py -h 127.0.0.1 -p 80 -a reading
UserParameter=nginx.Total-Requests,/usr/local/zabbix-3.0.0/scripts/getNginxInfo.py -h 127.0.0.1 -p 80 -a requests
UserParameter=nginx.Waiting-Connections,/usr/local/zabbix-3.0.0/scripts/getNginxInfo.py -h 127.0.0.1 -p 80 -a waiting
UserParameter=nginx.Writting-Connections,/usr/local/zabbix-3.0.0/scripts/getNginxInfo.py -h 127.0.0.1 -p 80 -a writing# 变量形式
UserParameter=nginx.status[*],/usr/local/zabbix-3.0.0/scripts/ngx_status.sh $1

getNginxInfo.py:

#!/bin/env python
#
# Options:
#
# -a active
# -a accepted
# -a handled
# -a requests
# -a reading
# -a writing
# -a waiting
#import urllib2, base64, sys, getopt
import re##def Usage ():print "Usage: getNginxInfo.py  -h 127.0.0.1 -p 80 -a [active|accepted|handled|request|reading|writing|waiting]"sys.exit(2)##def main ():# Default valueshost = "localhost"port = "80"getInfo = "None"if len(sys.argv) < 2:Usage()try:opts, args = getopt.getopt(sys.argv[1:], "h:p:a:")except getopt.GetoptError:Usage()# Assign parameters as variablesfor opt, arg in opts :if opt == "-h" :host = argif opt == "-p" :port = argif opt == "-a" :getInfo = argurl="http://" + host + ":" + port + "/nginx_status/"request = urllib2.Request(url)result = urllib2.urlopen(request)buffer = re.findall(r'\d{1,8}', result.read())## Format:
## Active connections: 196
## server accepts handled requests
## 272900 272900 328835
## Reading: 0 Writing: 6 Waiting: 190if ( getInfo == "active"):print buffer[0]elif ( getInfo == "accepted"):print buffer[1]elif ( getInfo == "handled"):print buffer[2]elif ( getInfo == "requests"):print buffer[3]elif ( getInfo == "reading"):print buffer[4]elif ( getInfo == "writing"):print buffer[5]elif ( getInfo == "waiting"):print buffer[6]else:print "unknown"sys.exit(1)if __name__ == "__main__":main()

ngx_status.sh

#!/bin/bashHOST="127.0.0.1"
PORT="8000"#检查 nginx 进程是否存在
function ping {/sbin/pidof nginx|wc -l
}#检查 nginx 性能
function active {/usr/bin/curl "http://$HOST:$PORT/nginx_status/" 2>/dev/null | grep 'Active '| awk '{print $NF}'
}function reading {/usr/bin/curl "http://$HOST:$PORT/nginx_status/" 2>/dev/null | grep 'Writing' | awk '{print $4}'
}function waiting {/usr/bin/curl "http://$HOST:$PORT/nginx_status/" 2>/dev/null | grep 'Waiting' | awk '{print $6}'
}function accepts {/usr/bin/curl "http://$HOST:$PORT/nginx_status/" 2>/dev/null | awk NR==3| awk '{print $1}'
}function handled {/usr/bin/curl "http://$HOST:$PORT/nginx_status/" 2>/dev/null | awk NR==3| awk '{print $2}'
}function requests {/usr/bin/curl "http://$HOST:$PORT/nginx_status/" 2>/dev/null | awk NR==3|awk '{print $3}'
}# 执行 funct
$1

zabbix_get 测试获取数据

[root@localhost ~]# /usr/local/zabbix-3.0.0/bin/zabbix_get -s 127.0.0.1 -k 'Nginx.Accepted-Connections'
17311

zabbix Web 端配置

导入 Template APP Nginx,并配置:

Zabbix 监控 Apache

Apache 监控原理跟 Nginx 相同,通过 Apache 的 status 模块获取数据,修改配置文件:

# 去掉注释
LoadModule status_module modules/mod_status.so# 末尾添加
ExtendedStatus On
<location /server-status>SetHandler server-statusOrder Deny,AllowDeny from allAllow from 127.0.0.1
</location>

curl http://localhost/server-status 即可获取 Apache 状态信息;

Zabbix 监控 php-fpm

php-fpm 和 nginx 一样内建了一个状态页,用于了解 php-fpm 的状态以及监控 php-fpm;

# cat  /usr/local/php-5.5.10/etc/php-fpm.conf | grep status_pathpm.status_path = /status

假设使用 Nginx 加载 PHP:

server {listen  *:80 default_server;server_name _;location ~ ^/(status|ping)${include fastcgi_params;fastcgi_pass 127.0.0.1:9000;fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;}}

由于 php-fpm 运行在 127.0.0.1:9000 端口上的,所以 curl http://localhost/status

pool:                 www
process manager:      dynamic
start time:           14/May/2016:22:40:15 +0800
start since:          58508
accepted conn:        33
listen queue:         0
max listen queue:     8
listen queue len:     0
idle processes:       2
active processes:     1
total processes:      3
max active processes: 5
max children reached: 0
slow requests:        2091

    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,那说明你的最大进程数量太小了,请改大一点。
slow requests # 启用了php-fpm slow-log,缓慢请求的数量

php-fpm 状态页比较个性化的一个地方是它可以带参数,可以带参数json、xml、html并且前面三个参数可以分别和full做一个组合。

curl http://127.0.0.1/status?json
curl http://127.0.0.1/status?xml
curl http://127.0.0.1/status?html
curl http://127.0.0.1/status?full

full 会多出几个状态:

pid # 进程PID,可以单独kill这个进程. You can use this PID to kill a long running process.
state # 当前进程的状态 (Idle, Running, …)
start time # 进程启动的日期
start since # 当前进程运行时长
requests # 当前进程处理了多少个请求
request duration # 请求时长(微妙)
request method # 请求方法 (GET, POST, …)
request URI # 请求URI
content length # 请求内容长度 (仅用于 POST)
user # 用户 (PHP_AUTH_USER) (or ‘-’ 如果没设置)
script # PHP脚本 (or ‘-’ if not set)
last request cpu # 最后一个请求CPU使用率。
last request memorythe # 上一个请求使用的内存

转载于:https://my.oschina.net/u/2470065/blog/845503

配置 Zabbix 监控 Nginx(Apache、php-fpm)相关推荐

  1. 配置zabbix监控nginx状态,监控华为路由器

    配置zabbix监控nginx状态,监控华为路由器 1.安装并开启nginx [root@localhost ~]# yum install nginx -y [root@localhost ~]# ...

  2. 手把手教你使用zabbix监控nginx

    zabbix监控nginx,多亏了容哥(杨容)的帮忙,为了感谢容哥的帮助,写了这篇文章. 环境介绍: 服务器系统版本:CentOSrelease 6.6 (Final) 内核版本:Linux hk_n ...

  3. zabbix监控nginx连接数

    一.nginx配置 nginx 1.6,zabbix 4.0.5 利用nginx自己的监控模块对nginx连接数进行监控 nginx配置: server {listen 80;server_name ...

  4. Zabbix监控Nginx连接状态

    检测Nginx模块 Nginx性能监控需要通过ngx_http_stub_status_module模块来收集指标: 1)检测是否编译ngx_http_stub_status_module模块 /us ...

  5. zabbix监控nginx状态,显示状态active,accepts,handled,requests

    zabbix监控nginx状态,显示状态active,accepts,handled,requests 一. 首先,zabbix server部署完成,可用. 接上篇zabbix部署文章,我这里zab ...

  6. zabbix监控nginx,网易Java面试流程

    同样的添加到之前的配置文件里面,重启agent端服务读取脚本 我们在server1验证,获取agent端的相关键值 同样的,分别添加三个监控项nginx_accept,nginx_handle,ngi ...

  7. zabbix监控nginx,PHP-FPM,ELK报警

    首先nginx编译安装此模块--with-http_stub_status_module 参考教程如下 Zabbix监控Nginx http://www.ttlsa.com/zabbix/zabbix ...

  8. zabbix监控nginx

    1.nginx添加ngx_http_stub_status_module模块 vim /etc/nginx/conf.d/default.conf location = /basic_status { ...

  9. Zabbix监控Nginx性能状态

    Nginx在生产环境中的应用越来越广泛,所以需要对nginx的性能状态做一些监控,从而发现故障隐患,Ngnx的监控指标可分为:基本活动指标,错误指标,性能指标 监控Nginx思路: 1)首先,要想监控 ...

最新文章

  1. java不同的数据源如何处理_java – 如何在不同的数据源上创建两个类之间的关系?...
  2. 2.2基本算法之递归和自调用函数_你为什么学不会递归?读完这篇文章轻松理解递归算法...
  3. 普元EOS开发积累第一篇(常见错误解决方法) 持续更新
  4. C++ primer 详解(第三章)
  5. centos7 apache2.4 多站点配置
  6. equals 和 hashCode 到底有什么联系?一文告诉你
  7. txt文本变为粗体_如何在PHP中使文本变为粗体?
  8. 图像变形功能的应用: 在线修整发型
  9. 每日一课(10/75)CPU资源和存储器 之 专用寄存器的作用
  10. 【LeetCode】026. Remove Duplicates from Sorted Array
  11. 关于rnn神经网络的loss函数的一些思考
  12. 生态丨人大金仓与超图集团共商战略新发展、共营和谐新生态!
  13. 在我的世界修改服务器吗 名字,我的世界怎么改名字
  14. k8s集群安装traefik 2.x (保证成功版)
  15. Java同步问题_Java多线程同步问题
  16. 用python玩3x3数字华容道
  17. xshell支持图形_Xshell打不开图形化界面,或许该这样做!
  18. C++ 2.吃雪糕吗
  19. 平面内有N个点,如何快速求出距离最近的点对?
  20. vue put 提交 400 Bad Request(有时候可以提交成功)

热门文章

  1. 宏BOOST_TEST_REF的用法程序
  2. Boost:使用mapd_view类将数字数组映射到设备内存
  3. ITK:重新采样标量图像
  4. DCMTK:将XML文档转换为DICOM文件或数据集
  5. DCMTK:测试DcmItem的newDicomElement()辅助方法
  6. VTK:PolyData之MiscPointData
  7. VTK:图片之ImageFFT
  8. OpenCV相机运动估计
  9. C语言实现pid算法(附完整源码)
  10. 大端和小端的区别,以及如何判断一台机器是大端还是小端?