一、概述
由于所有业务只有一个公网IP入口,无法统计到每个业务的流量带宽,好在nginx上通过域名进行业务区分,可以借助nginx-module-vts模块来实现需求。
本文将主要用到以下几个模块和工具:
nginx-module-vts: Nginx virtual host traffic status module,nginx的监控模块,能够提供json、html、prometheus格式的数据产出。
nginx-vts-exporter: Simple server that scrapes Nginx vts stats and exports them via HTTP for Prometheus consumption。主要用于收集nginx的监控数据,并给Prometheus提供监控接口,默认端口号9913。
Prometheus: 监控nginx-vts-exporter提供的nginx数据,并存储在时序数据库中,可以使用PromQL对时序数据进行查询和聚合。
Grafana: 可视化监控数据展示工具
二、基于docker方式部署
由于yum安装的nginx,默认是没有nginx-module-vts模块的。需要下载对应的nginx源码,进行重新编译才行。
为了快速演示,dockerhub已经有镜像了,包括nginx和nginx-module-vts模块
https://hub.docker.com/r/gaciaga/nginx-vts
环境介绍
本文采用一台服务器,来演示。
操作系统:centos 7.6
docker版本:19.03.8
ip地址:192.168.31.150
容器列表:prometheus,grafana,nginx-vts,nginx-vts-exporter
关于基于docker方式搭建prometheus+grafana,请参考链接:
https://www.cnblogs.com/xiao987334176/p/9930517.html
nginx-vts
nginx的监控模块,能够提供json、html、prometheus格式的数据产出。
下载镜像
docker pull gaciaga/nginx-vts
运行镜像
docker run -d -it -p 80:80 gaciaga/nginx-vts:latest
注意:此镜像,默认已经开启了status
访问status页面
http://192.168.31.150/status
效果如下:
nginx-vts-exporter
主要用于收集nginx的监控数据,并给Prometheus提供监控接口,默认端口号9913。
下载镜像
docker pull sophos/nginx-vts-exporter
运行镜像
docker run -d -it -e NGINX_STATUS="http://192.168.31.150/status/format/json" -p 9913:9913 sophos/nginx-vts-exporter
注意:请根据实际情况修改NGINX_STATUS变量,确保能正常访问。
访问metrics
http://192.168.31.150:9913/metrics
效果如下:
三、Prometheus配置
修改prometheus.yml,最后一行添加
- job_name: nginx-vts static_configs: - targets: ['192.168.31.150:9913'] labels: instance: localhost
重启prometheus
docker restart prometheus
查看targets
http://192.168.31.150:9090/targets
效果如下:
确保状态为UP
四、Grafana配置
导入nginx vts模板
访问地址
https://grafana.com/grafana/dashboards/2949/revisions
点击Download,下载json文件
导入json文件
效果如下:
本文参考链接:
https://www.cnblogs.com/91donkey/p/11643558.html