来自公众号:马哥Linux运维
作者:马哥企业教练团队
检测Nginx模块
Nginx性能监控需要通过ngx_http_stub_status_module
模块来收集指标: 1)检测是否编译ngx_http_stub_status_module
模块
/usr/local/nginx/sbin/nginx -V
如果未启用ngx_http_stub_status_module
模块则重新编译Nginx,具体操作不在叙述
2)Nginx配置文件添加模块配置
location /ngx_status {
stub_status on; #开启stub_status模块
allow 127.0.0.1; #只允许127.0.0.1本地访问
access_log off; #不记录日志,如果需要记录日志,删除此行即可
deny all; #除了以上允许127.0.0.1以外,拒绝所有地址访问
}
3)重启Nginx
/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -s reload
4)访问stub_statub模块
curl http://127.0.0.1/ngx_status
Active connections: 1
server accepts handled requests
16214 16214 8269
Reading: 0 Writing: 1 Waiting: 0
参数详解: Active connections
:Nginx当前活动客户端连接的数量,包括正在等待的连接 accepts
:Nginx已经接受客户端的连接总数量 handled
:Nginx已经处理客户端的连接总数量 requests
:客户端发送的请求的总数量 Reading
:Nginx服务器当前正在读取客户端请求头的数量 Writing
:Nginx服务器当前正在写响应信息的数量 Waiting
:当前有多少客户端在等待Nginx服务器响应
编写Nginx监控脚本
1)编写监控脚本 vim /usr/local/zabbix/scripts/ngx_status.sh
#!/usr/bin/env bash
HOST='127.0.0.1'
PORT='80'
#Nginx进程监控,进程存在值为1,进程停止值为0
function ping {
/sbin/pidof nginx | wc -l
}
#Nginx当前活动客户端连接的数量,包括正在等待的连接
function active {
/bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | grep 'Active' | awk '{print $NF}'
}
#Nginx服务器当前正在读取客户端请求头的数量
function reading {
/bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | grep 'Reading' | awk '{print $2}'
}
#Nginx服务器当前正在写响应信息的数量
function writing {
/bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | grep 'Writing' | awk '{print $4}'
}
#当前有多少客户端在等待服务器响应
function waiting {
/bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | grep 'Waiting' | awk '{print $6}'
}
#Nginx已经接受客户端的连接总数量
function accepts {
/bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | awk NR==3 | awk '{print $1}'
}
#Nginx已经处理客户端的连接总数量
function handled {
/bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | awk NR==3 | awk '{print $2}'
}
#客户端发送的请求的总数量
function requests {
/bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | awk NR==3 | awk '{print $3}'
}
$1
2) 修改权限属性
chown -Rf zabbix.zabbix /usr/local/zabbix/scripts/ngx_status.sh
chmod u+x /usr/local/zabbix/scripts/ngx_status.sh
Zabbix_GET数据测试
到zabbix_agentd.conf配置文件中指定Server的主机上进行zabbix_get数据测试
zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[ping]"
1
zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[active]"
1
zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[reading]"
0
zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[writing]"
1
zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[waiting]"
0
zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[accepts]"
16342
zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[handled]"
16345
zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[requests]"
8402
编写键值
1) 编写键值脚本
vim /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_ngx_status.conf
UserParameter=ngx.status[*],/usr/local/zabbix/scripts/ngx_status.sh $1
重启Zabbix-Agentd
/etc/init.d/zabbix_agentd restart
Zabbix_Web创建模板及监控项
1)创建模板 主页面点击 配置——》模板——》创建模板
2)创建应用集
3)创建监控项 进入模板后——》监控项——》创建监控项
最后创建好如下:
4)创建触发器 对进程监控添加触发器,触发器——》创建触发器 填入触发器名称,此名称是告警出的信息——》选择严重性——》添加表达式——》我这里是使用了last
函数最新的值如果等于0则触发告警,恢复表达式为last
函数最新的至等于1则恢复告警。
最后创建好如下:又创建了一个当客户端等待Nginx服务器响应数量大于100则告警的触发器
5) 创建图形 我这里把Nginx性能监控的监控项都放到了图形中,除进程监控外
主机嵌套模板
配置——》主机——》进入需要监控Nginx性能的主机——》模板——》添加模板——》选中我们创建的模板
查看数据
监测——》最新数据——》选中节点——》选中应用集
通过图形查看数据