Prometheus实战篇:Prometheus监控nginx
准备环境
在此专栏的前几篇文章中已经准备了一台服务器作为我们进行环境的准备.大家也可以通过虚拟机创建俩台服务器,一台作为Prometheus的安装另外一台进行其他软件安装并且进行监控的服务器.
这里我就不赘述nginx的安装教程,相信大家都可以搜到,使用docker或者直接通过安装包解压的方式都可以,我这里是通过docker的方式进行安装的,后面的操作其实都是大差不差的.
nginx开启stub_status
- 监控nginx需要with-http_stub_status_module这个模块
首先检查是否有安装with-http_stub_status_module模块
docker方式安装
代码语言:shell复制docker exec -it nginx nginx -v 2>&1 |grep -o with-http_stub_status_module
nginx安装包方式安装
代码语言:shell复制nginx nginx -v 2>&1 |grep -o with-http_stub_status_module
nginx开启stub_status配置
将下面配置文件写到nginx.conf配置文件中:
代码语言:nginx复制server {
.....
location /stub_status {
stub_status on;
access_log off;
allow 0.0.0.0/0;
deny all;
}
....
}
重新加载配置文件
代码语言:txt复制docker exec -it nginx nginx -s reload
检查是否开启成功
代码语言:txt复制curl http://localhost/syub_status
成功如下图:
安装Exporter
在上篇文章中说了Prometheus需要监控什么软件需要对应安装的Exporter,当然这里可以使用二进制安装也可以使用docker安装.这里为了方便,还是选择docker-compose的方式直接安装
docker-compose方式进行安装
这里直接通过创建docker-compose.yaml然后进行追加配置
代码语言:shell复制cat >docker-compose.yaml <<FOF
version: '3.3'
services:
nginx_exproter:
image:nginx/nginx-prometheus-exporter:0.11
container_name: nginx_exporter
hostname: nginx_exporter
command:
- '-nginx.scrape-uri=http://localhost/stub_status'
restart: always
port:
- "9113:9113"
EOF
启动
代码语言:shell复制docker-compose up -d
检查
代码语言:txt复制查看正在运行的容器
docker ps
或者:
查看nginx_exporter容器的运行日志
docker logs -f nginx_exporter
metrics地址
安装好Exporter后会暴露一个/metrics结尾的服务
名称 | 地址 |
---|---|
nginx_exporter | http://localhost:9113/metrics |
Prometheus配置
配置Prometheus去采集(拉取)nginx_exporter的监控样本数据
代码语言:shell复制cd /data/docker-prometheus
# 在scrapc_configs(搜刮配置):下面增加如下配置:
cat >prometheus/prometheus.yml <<FOF
- job_name: 'nginx_exporter'
static_configs:
- targets: ['localhost:9113']
labels:
instance: test服务器
EOF
重新加载配置
代码语言:shell复制curl -x POST http://localhost:9090/-/reload
检查
常用的nginx监控指标
代码语言:txt复制nginx_connections_accepted 接受请求数
nginx_connections_active 活动连接数
nginx_connections_handled 成功处理请求数
nginx_connections_reding 正在进行读操作的请求数
nginx_connections_waiting 正在等待的请求数
nginx_connections_writing 正在进行写操作的请求数
nginx_connections_requests 总请求数
添加触发器
代码语言:shell复制cd /data/docker-prometheus
代码语言:shell复制cat >prometheus/alert.yml <<FOF
-name: nginx
rules:
# 任何势力超过30秒无法联系的情况发出警报
- alert: NginxDown
expr: nginx_up ==0
for: 30s
labels:
severity: critical
annotations:
summary:"nginx异常,实例:{{$labels.instance }}"
description: "{{$lables.job}} nginx已关闭"
EOF
检查:
代码语言:shell复制vim prometheus/alert.yml
检查配置
代码语言:shell复制docker exec -it prometheus promtool check config /etc/prometheus/prometheus.yml
重新加载配置
代码语言:shell复制curl -x POST http://localhost:9090/-/reload
检查
http://localhost:9090/alerts?search=
或:
http://localhost:9090/rules
dashboard
grafana展示Prometheus从nginx_exporter收集到的数据