监控利器:普罗米修斯监控中间件(Nginx、Redis、MySql 等)

本文详细介绍了如何使用Prometheus监控Nginx、Redis、RabbitMQ和MySql等常见中间件,包括安装exporter、配置容器和Prometheus,以及在Grafana中展示监控结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们的产品目前使用到的中间件有 Nginx、Redis、RabbitMQ、MySql 等,本文介绍怎样使用 Promtheus 来监控这些中间件。

在《监控利器:普罗米修斯介绍和安装》中有一张图,表明了 Prometheus 的数据走向,如下:

71c3f67c43e50c467fccfe522094cfba.jpeg

从图中可以看出,监控中间件的第一步就是安装中间件的 exporter,安装有两种方式:下载安装文件进行安装和使用 Docker 进行安装,下面示例中使用的是后者。

Nginx

1、我们产品的前端 Web 部署在 nginx 容器中,需要在容器的配置文件中进行 nginx_status 模块的设置,才能被 exporter 识别。nginx 配置文件添加下面代码:

location /nginx_status {
        stub_status on;
        access_log off;
        allow all;
       # deny all;
 }
  • 为了测试方便直接设置为 allow all 了,实际可以根据需要进行开放和禁用。

2、修改配置后,重启 Web 容器,访问 http://ip:port/nginx_status  ,出现下图界面,说明配置生效:

6ad88552055bbb1b5f35bd41f4a86e71.jpeg

3、执行下面的命令进行 nginx-exporter 容器的安装:

docker pull nginx/nginx-prometheus-exporter
docker run -p 9113:9113 -d  --restart=always --name nginx-exporter nginx/nginx-prometheus-exporter -nginx.scrape-uri http://10.211.55.3:90/nginx_status
  • http://192.168.3.78/nginx_status 为被监控的 nginx 服务器的地址。

容器运行后,访问 9113 端口,如下图:

6c917da947ca5a9eda32e79c576b6050.jpeg

4、在 prometheus 的配置文件中进行绑定,执行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加  job 配置:

3c4223649f5edcf6108c8b48333833b1.jpeg
- job_name: 'nginx'
    static_configs:
      - targets: ['10.211.55.3:9113']

5、执行命令 systemctl restart prometheus 重启生效,可以访问 http://10.211.55.3:9090/targets 查看状态,如果为 UP 说明 job 设置成功:

08b8f7b143161ec67d6ca6b84b48b825.jpeg

6、在 Grafana 中导入 12078 模板:

1641043c023572e668ae27b021575af8.jpeg

7、最终展示效果如下:

bf91464f8b480bf4f98bbeda45444e26.jpeg

Redis

1、首先需要安装 redis_exporter ,执行下面命令进行镜像的下载和安装:

docker pull oliver006/redis_exporter 
# 如果 redis 没有密码执行下面命令
docker run -d --name redis_exporter -p 9121:9121   --network s2v9_test_s2_net  oliver006/redis_exporter --redis.addr redis://172.66.9.9:6379 
# 如果 redis 有密码执行下面命令
docker run -d --name redis_exporter -p 9121:9121   --network s2v9_test_s2_net  oliver006/redis_exporter --redis.addr redis://172.66.9.9:6379 --redis.password '000000'
  • 上面命令中 --network s2v9_test_s2_net 为 redis 容器所在的网络,因为我的 exporter 容器和 redis 容器在一台服务器,设置为同一网络后,--redis.addr 就可以使用容器的内部 IP 和端口。

  • 如果是分开部署,不需要设置 --network ,使用服务器 IP 和端口即可。

2、容器运行成功后,浏览器访问界面如下:

aab580ce7605e0a0c76c951d42c40ee6.jpeg

3、在 prometheus 的配置文件中进行绑定,执行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:

632079d0d99c03f79d97d4fc2dfed5f5.jpeg
- job_name: 'reids'
    static_configs:
      - targets: ['10.211.55.3:9121']

4、执行命令 systemctl restart prometheus 重启生效,可以访问 http://10.211.55.3:9090/targets 查看状态,如果为 UP 说明 job 设置成功:

7308f6449498fe5ba7705e9d2479731d.jpeg

5、在 Grafana 中导入 763 编号的模板:

6a734afbce7c9f1d65b837ed884ae0e1.jpeg

6、最终展示效果如下:

7e5be3cac1909fa1b8c486be6963e8f1.jpeg

RabbitMQ

1、首先需要安装 redis_exporter ,执行下面命令进行镜像的下载和安装:

docker pull kbudde/rabbitmq-exporter:latest

docker run -d -p 9419:9419 --name rabbitmq-exporter --network s2v9_test_s2_net -e RABBIT_URL=http://172.66.9.8:15672 -e RABBIT_USER=Ican -e RABBIT_PASSWORD=000000 kbudde/rabbitmq-exporter
  • -e RABBIT_URL=http://172.66.9.8:15672 ,这里设置的是 RabbitMQ 容器的内部 IP,所以必须设置在同一个网络中,否则需要将 15672 映射出去。

  • -e RABBIT_USER、-e RABBIT_PASSWORD 为 RabbitMQ 的用户名和密码,默认为 guest,也可以自行设置。

2、容器运行成功后,浏览器访问界面如下:

4a9e9679b6df6b7f40eccdbb2fca5e78.jpeg

3、在 prometheus 的配置文件中进行绑定,执行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:

230eb04e248b9d1504e40e46cefd5dbd.jpeg
- job_name: 'rabbitmq'
    static_configs:
      - targets: ['10.211.55.3:9419']

4、执行命令 systemctl restart prometheus 重启生效,可以访问 http://10.211.55.3:9090/targets 查看状态,如果为 UP 说明 job 设置成功:

b9d5c9c3ab8167bbec495599824b4142.jpeg

5、在 Grafana 中导入 2121 编号的模板:

d36890508736d84bc2bec8262204647f.jpeg

6、最终展示效果如下:

b2e7ae888bbc26c50113ee8d1c8a7a8b.jpeg

MySql

1、在 mysql 数据库中创建 exporter 账户,并设置权限:

CREATE USER 'exporter'@'%' IDENTIFIED BY 'Aa123456';
GRANT PROCESS, REPLICATION CLIENT ON *.* TO 'exporter'@'%';
GRANT SELECT ON performance_schema.* TO 'exporter'@'%';

2、在目录 /root/exporter/config/mysql 中创建 .my.cnf 文件,文件内容如下:

[client]
host=172.66.9.2
port=3306
user=exporter
password=Aa123456
  • host 配置为 mysql 数据库的容器 IP

  • user 和 password 配置为新创建的账号和密码

3、执行下面命令安装 mysqld-exporter :

docker pull prom/mysqld-exporter
docker run -d -p 9104:9104 --network s2v9_test_s2_net --restart="always" -v /root/exporter/config/mysql/.my.cnf:/.my.cnf prom/mysqld-exporter

如果没有 .my.cnf 文件的映射,会出现下面错误:

87d534a0a05dd93b63cc997c685aa853.jpeg

4、容器运行成功后,浏览器访问界面如下:

820b83a0a069cc865500a9148ccc0b64.jpeg

5、在 prometheus 的配置文件中进行绑定,执行vi /usr/local/prometheus/prometheus.yml,在文件的最下面添加 job 配置:

3685b1f7ee387008f7aaa4a70ec16f7c.jpeg
- job_name: 'mysql'
    static_configs:
      - targets: ['10.211.55.3:9104']

6、执行命令 systemctl restart prometheus 重启生效,可以访问 http://10.211.55.3:9090/targets 查看状态,如果为 UP 说明 job 设置成功:

085a35ffaff706c78640b7f10a0885ec.jpeg

7、在 Grafana 中导入 7362 编号的模板:

a533597ab9d84a5f96ffff7865643852.jpeg

8、最终展示效果如下:

570a1a8ce4be359e110838a916df3c26.jpeg
### 使用 Prometheus 监控 Nginx 容器的最佳实践 为了有效地使用 Prometheus 监控运行中的 Nginx 容器,可以遵循以下最佳实践: #### 配置 Nginx Exporter Nginx Exporter 是一个用于收集 Nginx 性能指标并将其提供给 Prometheus 的工具。对于容器化部署,建议将 Nginx Exporter 作为单独的容器与 Nginx 主应用一起启动。 ```yaml version: '3' services: nginx: image: nginx:latest ports: - "80:80" volumes: - ./nginx.conf:/etc/nginx/nginx.conf nginx-exporter: image: prom/nginx-vts-exporter:latest environment: NGINX_VTS_STATUS_URI: http://nginx-server-status/ depends_on: - nginx ``` 此 Docker Compose 文件定义了一个服务组,其中 `nginx` 提供 Web 内容,而 `nginx-exporter` 收集性能数据[^2]。 #### 修改 Nginx 配置文件支持监控模块 为了让 Nginx 出现可被采集的数据端口,在其配置文件中加入如下设置: ```nginx http { vhost_traffic_status_zone; server { listen 80; server_name localhost; location /status { vhost_traffic_status_display; allow 127.0.0.1; # 只允许本地访问状态页面 deny all; } } } ``` 这段配置启用了虚拟主机流量状态功能,并开放 `/status` 接口来展示统计信息[^3]。 #### 更新 Prometheus 配置抓取目标 最后一步是在 Prometheus 中添加新的 scrape target 来定期拉取来自 Nginx Exporter 的度量标准: ```yaml scrape_configs: - job_name: 'nginx' static_configs: - targets: ['nginx-exporter-service-name:9113'] ``` 这里假设 `nginx-exporter-service-name` 是指向 Nginx Exporter 实例的服务名称或 IP 地址。 通过上述操作,能够实现对 Nginx 容器内部工作情况的有效监测,从而更好地理解应用程序的表现并及时响应潜在问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值