百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

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

mhr18 2025-04-09 17:56 11 浏览 0 评论

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

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

从图中可以看出,监控中间件的第一步就是安装中间件的 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 ,出现下图界面,说明配置生效:

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 端口,如下图:

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

 - job_name: 'nginx'
static_configs:
- targets: ['10.211.55.3:9113']

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

6、在 Grafana 中导入 12078 模板:

7、最终展示效果如下:

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、容器运行成功后,浏览器访问界面如下:

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

 - job_name: 'reids'
static_configs:
- targets: ['10.211.55.3:9121']

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

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

6、最终展示效果如下:

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、容器运行成功后,浏览器访问界面如下:

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

 - job_name: 'rabbitmq'
static_configs:
- targets: ['10.211.55.3:9419']

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

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

6、最终展示效果如下:

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 文件的映射,会出现下面错误:

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

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

 - job_name: 'mysql'
static_configs:
- targets: ['10.211.55.3:9104']

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

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

8、最终展示效果如下:




相关推荐

【推荐】一个开源免费、AI 驱动的智能数据管理系统,支持多数据库

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!.前言在当今数据驱动的时代,高效、智能地管理数据已成为企业和个人不可或缺的能力。为了满足这一需求,我们推出了这款开...

Pure Storage推出统一数据管理云平台及新闪存阵列

PureStorage公司今日推出企业数据云(EnterpriseDataCloud),称其为组织在混合环境中存储、管理和使用数据方式的全面架构升级。该公司表示,EDC使组织能够在本地、云端和混...

对Java学习的10条建议(对java课程的建议)

不少Java的初学者一开始都是信心满满准备迎接挑战,但是经过一段时间的学习之后,多少都会碰到各种挫败,以下北风网就总结一些对于初学者非常有用的建议,希望能够给他们解决现实中的问题。Java编程的准备:...

SQLShift 重大更新:Oracle→PostgreSQL 存储过程转换功能上线!

官网:https://sqlshift.cn/6月,SQLShift迎来重大版本更新!作为国内首个支持Oracle->OceanBase存储过程智能转换的工具,SQLShift在过去一...

JDK21有没有什么稳定、简单又强势的特性?

佳未阿里云开发者2025年03月05日08:30浙江阿里妹导读这篇文章主要介绍了Java虚拟线程的发展及其在AJDK中的实现和优化。阅前声明:本文介绍的内容基于AJDK21.0.5[1]以及以上...

「松勤软件测试」网站总出现404 bug?总结8个原因,不信解决不了

在进行网站测试的时候,有没有碰到过网站崩溃,打不开,出现404错误等各种现象,如果你碰到了,那么恭喜你,你的网站出问题了,是什么原因导致网站出问题呢,根据松勤软件测试的总结如下:01数据库中的表空间不...

Java面试题及答案最全总结(2025版)

大家好,我是Java面试陪考员最近很多小伙伴在忙着找工作,给大家整理了一份非常全面的Java面试题及答案。涉及的内容非常全面,包含:Spring、MySQL、JVM、Redis、Linux、Sprin...

数据库日常运维工作内容(数据库日常运维 工作内容)

#数据库日常运维工作包括哪些内容?#数据库日常运维工作是一个涵盖多个层面的综合性任务,以下是详细的分类和内容说明:一、数据库运维核心工作监控与告警性能监控:实时监控CPU、内存、I/O、连接数、锁等待...

分布式之系统底层原理(上)(底层分布式技术)

作者:allanpan,腾讯IEG高级后台工程师导言分布式事务是分布式系统必不可少的组成部分,基本上只要实现一个分布式系统就逃不开对分布式事务的支持。本文从分布式事务这个概念切入,尝试对分布式事务...

oracle 死锁了怎么办?kill 进程 直接上干货

1、查看死锁是否存在selectusername,lockwait,status,machine,programfromv$sessionwheresidin(selectsession...

SpringBoot 各种分页查询方式详解(全网最全)

一、分页查询基础概念与原理1.1什么是分页查询分页查询是指将大量数据分割成多个小块(页)进行展示的技术,它是现代Web应用中必不可少的功能。想象一下你去图书馆找书,如果所有书都堆在一张桌子上,你很难...

《战场兄弟》全事件攻略 一般事件合同事件红装及隐藏职业攻略

《战场兄弟》全事件攻略,一般事件合同事件红装及隐藏职业攻略。《战场兄弟》事件奖励,事件条件。《战场兄弟》是OverhypeStudios制作发行的一款由xcom和桌游为灵感来源,以中世纪、低魔奇幻为...

LoadRunner(loadrunner录制不到脚本)

一、核心组件与工作流程LoadRunner性能测试工具-并发测试-正版软件下载-使用教程-价格-官方代理商的架构围绕三大核心组件构建,形成完整测试闭环:VirtualUserGenerator(...

Redis数据类型介绍(redis 数据类型)

介绍Redis支持五种数据类型:String(字符串),Hash(哈希),List(列表),Set(集合)及Zset(sortedset:有序集合)。1、字符串类型概述1.1、数据类型Redis支持...

RMAN备份监控及优化总结(rman备份原理)

今天主要介绍一下如何对RMAN备份监控及优化,这里就不讲rman备份的一些原理了,仅供参考。一、监控RMAN备份1、确定备份源与备份设备的最大速度从磁盘读的速度和磁带写的带度、备份的速度不可能超出这两...

取消回复欢迎 发表评论: