prometheus监控nginx的两种方式

Nginx监控搭建介绍说明

文章介绍两种不同的Nginx监控方法,第一种是nginx自带的tub_status模块进行监控,第二种是用vts监控工具进行监控。都是基于prometheus、grafana结合第三方模块或监控工具搭建,监控Nginx中间件的使用情况 。

方法一、tub_status模块监控

  1. 下载 https://github.com/nginxinc/nginx-prometheus-exporter/releases
  2. 解压 tar -zxvf
  3. 开启nginx_stub_status模块
    开源nginx提供了一个简单页面用于展示状态数据,该页面由tub_status模块提供,如果已在本地服务安装nginx,进入nginx/sbin目录下执行
./nginx -V 2>&1 | grep -o with-http_stub_status_module
  1. 如果在终端输出with-http_stub_status_module,说明nginx已启用tub_status模块;

在这里插入图片描述
yum安装的是二进制文件,意思是已经编译好的nginx,它只有配置文件和二进制文件,没有源代码,所以你想加第三方模块,只能去nginx的官方网站:http://nginx.org 下载源代码,使用**–with-http_stub_status_module**参数从源码重新编译安装;

./configure --prefix=/DATA/soft/nginx/ --with-http_stub_status_module  --add-module=nginx-module-vts
make
sudo make install
  1. 确认stub_status模块启动之后,修改nginx的配置文件指定status页面的URL;
    server {
        listen   80;  
        #端口可以自己重新起一个,配置文件要在外层nginx.conf中添加
        location /nginx_status {
            stub_status on;
            access_log off;
            allow 127.0.0.1;
            deny all;
        }
}
  1. 执行命令启动nginx-prometheus -exporter
nohup ./nginx-prometheus-exporter -nginx.scrape-uri http://127.0.0.1:80/nginx_status &

启动成功如图所示启动成功如图所示
7. prometheus.yml文件添加被监控的机器节点;

- job_name: 'nginx_status_module' # 采集nginx的指标
  metrics_path: '/metrics' # 拉取指标的接口路径
  scrape_interval: 10s # 采集指标的间隔周期
  static_configs:
  - targets: ['127.0.0.1:9113'] # nginx-prometheus-exporter服务的ip和端口
  1. 重新启动prometheus后,导入grafan模板;
    模板链接:https://grafana.com/grafana/dashboards/12708

在这里插入图片描述

方法二、vts工具监控

  1. vts模块下载,链接:https://github.com/vozlt/nginx-module-vts
  2. tar -zxvf 解压nginx-module-vts,监控模块放至nginx目录下

在这里插入图片描述
3. nginx源码文件重新编译安装

./configure --prefix=/DATA/soft/nginx/ --with-http_stub_status_module  --add-module=nginx-module-vts
make
sudo make install
  1. 修改nginx配置
#nginx配置server中添加:
location /status {
        vhost_traffic_status_display;
        vhost_traffic_status_display_format html;
        }
    }

#http中添加:
vhost_traffic_status_zone;
vhost_traffic_status_filter_by_host on;
  1. 添加系统变量,启动nginx
vi /usr/lib/systemd/system/nginx.service 
[Unit]
Description=nginx
After=network.target

[Service]
Type=forking
ExecStart=/DATA/soft/nginx/sbin/nginx
ExecReload=DATA/soft/nginx/sbin/nginx -s reload
ExecStop=DATA/soft/nginx/sbin/nginx -s quit
PrivateTmp=true

[Install]
WantedBy=multi-user.target
# 完成启动:
systemctl enable nginx.service
systemctl start nginx.service
systemctl status nginx.service

启动nginx后访问http://locahost/status
在这里插入图片描述
6. 安装启动nginx-vts-exporter
下载链接:https://github.com/hnlq715/nginx-vts-exporter
tar -zxvf解压
chmod +x /usr/local/nginx_exporter/bin/nginx-vts-exporter -R #整个路径添加权限
7. nginx-vts-exporter设置系统变量

vim /usr/lib/systemd/system/nginx_exporter.service

[Unit]
Description=nginx_vts_exporter
After=network.target

[Service]
Type=simple
ExecStart=/usr/local/nginx_exporter/bin/nginx-vts-exporter  -nginx.scrape_uri http://192.168.62.75/status/format/json   #ip替换成需要监控的ip
Restart=on-failure

[Install]
WantedBy=multi-user.target

启动nginx_exporter

systemctl enable nginx_exporter.service
systemctl status nginx_exporter.service
systemctl start nginx_exporter.service

在这里插入图片描述
8. 修改prometheus配置文件并重启
netstat -anlp | grep nginx-vts #查看nginx_vts_exporter启动的端口

- job_name: 'nginx'
  static_configs:
  - targets: ['127.0.0.1:9913']  #9913为工具启动的端口
    labels:
      instance: nginx
  1. grafana导入nginx-vts-exporter监控模板
    模板链接:https://grafana.com/grafana/dashboards/2949

在这里插入图片描述
在这里插入图片描述

  • 7
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
一、prometheus简介 Prometheus是一个开源的系统监控和告警系统,现在已经加入到CNCF基金会,成为继k8s之后第二个在CNCF维护管理的项目,在kubernetes容器管理系统中,通常会搭配prometheus进行监控prometheus支持多种exporter采集数据,还支持通过pushgateway进行数据上报,Prometheus再性能上可支撑上万台规模的集群。 二、prometheus架构图 三、prometheus组件介绍 1.Prometheus Server: 用于收集和存储时间序列数据。 2.Client Library: 客户端库,检测应用程序代码,当Prometheus抓取实例的HTTP端点时,客户端库会将所有跟踪的metrics指标的当前状态发送到prometheus server端。 3.Exporters: prometheus支持多种exporter,通过exporter可以采集metrics数据,然后发送到prometheus server端 4.Alertmanager: 从 Prometheus server 端接收到 alerts 后,会进行去重,分组,并路由到相应的接收方,发出报警,常见的接收方式有:电子邮件,微信,钉钉, slack等。 5.Grafana:监控仪表盘 6.pushgateway: 各个目标主机可上报数据到pushgatewy,然后prometheus server统一从pushgateway拉取数据。 四、课程亮点 五、效果图展示 六、讲师简介 先超(lucky):高级运维工程师、资深DevOps工程师,在互联网上市公司拥有多年一线运维经验,主导过亿级pv项目的架构设计和运维工作 主要研究方向: 1.云计算方向:容器 (kubernetes、docker),虚拟化(kvm、Vmware vSphere),微服务(istio),PaaS(openshift),IaaS(openstack)等2.系统/运维方向:linux系统下的常用组件(nginx,tomcat,elasticsearch,zookeeper,kafka等),DevOps(Jenkins+gitlab+sonarqube+nexus+k8s),CI/CD,监控(zabbix、prometheus、falcon)等 七、课程大纲
Prometheus可以监控nginx的流量。通过使用Prometheus的插件或者导出器可以收集nginx监控数据。其中,可以使用nginx-vts-exporter来收集Nginx监控数据,并将其通过HTTP暴露给Prometheus进行消费。nginx-vts-exporter是一个简单的服务器,它会抓取Nginx的vts(虚拟主机统计)统计数据,并通过HTTP接口提供给Prometheus。默认情况下,nginx-vts-exporter监听的端口号是9913。 Prometheus具有多维数据模型,可以很好地对nginx的指标进行收集和存储,例如流量。你可以自定义Prometheus的数据标签,以便针对不同的机房和项目对nginx进行监控。这样,你可以根据需要对各个维度的流量进行可视化展示,也可以使用Grafana等工具来生成图像展示和监控报告。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [用PrometheusNginx监控](https://blog.csdn.net/weixin_41709748/article/details/88063548)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [使用prometheus监控nginx](https://blog.csdn.net/Mob_com/article/details/89312413)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值