基于 Prometheus + Grafana 监控微服务和数据库
以下是基于 Prometheus + Grafana 监控微服务和数据库的详细指南,包含架构设计、安装配置及验证步骤:
一、整体架构设计

二、监控微服务
1. 微服务指标暴露
- Spring Boot 应用:
xml
<!-- 添加 Micrometer 依赖 --> <dependency><groupId>io.micrometer</groupId><artifactId>micrometer-registry-prometheus</artifactId> </dependency>- 配置文件 (
application.yml):yaml
management:endpoints:web:exposure:include: prometheusmetrics:tags:application: your-service-name - 访问指标:
http://<微服务IP>:端口/actuator/prometheus
- 配置文件 (
2. Prometheus 配置
修改 prometheus.yml 添加微服务监控:
yaml
scrape_configs:- job_name: 'microservices'static_configs:- targets: ['ms1:8080', 'ms2:8080'] # 微服务实例地址
三、监控数据库
1. MySQL 监控
- 安装 mysqld_exporter:
bash
wget https://github.com/prometheus/mysqld_exporter/releases/download/v0.15.0/mysqld_exporter-0.15.0.linux-amd64.tar.gz tar -zxvf mysqld_exporter-0.15.0.linux-amd64.tar.gz - 配置数据库权限:
sql
CREATE USER 'exporter'@'%' IDENTIFIED BY 'password'; GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO 'exporter'@'%'; - 启动 Exporter:
bash
./mysqld_exporter --config.my-cnf=~/.my.cnf
2. Oracle 监控
- 安装 oracledb_exporter:
bash
wget https://github.com/iamseth/oracledb_exporter/releases/download/v0.2.8/oracledb_exporter.linux-amd64 chmod +x oracledb_exporter.linux-amd64 - 配置连接信息:
yaml
# config.yml data_source: system/password@//localhost:1521/orcl - 启动 Exporter:
bash
./oracledb_exporter --config.path=config.yml
3. Prometheus 配置
yaml
scrape_configs:- job_name: 'mysql'static_configs:- targets: ['mysql-server:9104'] # mysqld_exporter 默认端口 9104- job_name: 'oracle'static_configs:- targets: ['oracle-server:9182'] # oracledb_exporter 默认端口 9182
四、Grafana 配置
1. 添加数据源
- 登录 Grafana(
http://<服务器IP>:3000),进入 Configuration → Data Sources。 - 选择 Prometheus,填写 URL(如
http://prometheus-server:9090),保存并测试连接。
2. 导入仪表盘
- 微服务监控:
- 模板 ID:
13978(Spring Boot 监控)
- 模板 ID:
- MySQL 监控:
- 模板 ID:
7362(MySQL Overview)
- 模板 ID:
- Oracle 监控:
- 模板 ID:
15222(Oracle Database Monitoring)
- 模板 ID:
3. 自定义告警规则
在 Grafana 中创建告警规则(如数据库连接数阈值):
- 进入 Alerting → Rules,选择数据源。
- 编写 PromQL 查询,设置阈值和通知渠道(邮件 / Slack / 钉钉)。
五、验证与调优
-
Prometheus 验证:
- 访问
http://prometheus-server:9090/targets,确保所有 Exporter 状态为UP。 - 使用 PromQL 查询指标(如
node_cpu_seconds_total)。
- 访问
-
Grafana 验证:
- 检查仪表盘数据是否实时更新。
- 测试告警规则是否触发通知。
-
性能优化:
- 调整
scrape_interval(默认 15s)以平衡数据密度和性能。 - 配置
storage.tsdb.retention.time控制数据保留时长(默认 15 天)。
- 调整
六、扩展方案
- 动态服务发现:
- 使用 Kubernetes DNS 或 Consul 自动发现微服务实例。
- 修改 Prometheus 配置为:
yaml
scrape_configs:- job_name: 'kubernetes-pods'kubernetes_sd_configs:- role: pod
- 高可用部署:
- 使用 Prometheus Operator 在 Kubernetes 中部署集群。
- 配置 Grafana 主从节点和持久化存储。
案例:
下面将详细介绍如何使用 Prometheus 和 Grafana 对 Spring Boot 应用以及 MySQL、Redis、MongoDB 数据库进行监控。
1. 监控 Spring Boot 应用
1.1 暴露 Spring Boot 应用指标
在 Spring Boot 项目的 pom.xml 中添加以下依赖:
xml
<dependency><groupId>io.micrometer</groupId><artifactId>micrometer-registry-prometheus</artifactId>
</dependency>
在 application.yml 或 application.properties 中进行如下配置:
yaml
management:endpoints:web:exposure:include: prometheusmetrics:tags:application: your-application-name
配置完成后,Spring Boot 应用会在 /actuator/prometheus 端点暴露 Prometheus 格式的指标。
1.2 配置 Prometheus 监控 Spring Boot 应用
在 prometheus.yml 中添加如下配置:
yaml
scrape_configs:- job_name: 'spring-boot-app'static_configs:- targets: ['your-spring-boot-app-ip:port']
2. 监控 MySQL 数据库
2.1 安装并配置 mysqld_exporter
从 mysqld_exporter 发布页面 下载适合你系统的版本并解压。
为 mysqld_exporter 创建 MySQL 用户并授予必要的权限:
sql
CREATE USER 'exporter'@'%' IDENTIFIED BY 'password';
GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO 'exporter'@'%';
启动 mysqld_exporter:
bash
./mysqld_exporter --config.my-cnf=~/.my.cnf
2.2 配置 Prometheus 监控 MySQL
在 prometheus.yml 中添加以下配置:
yaml
scrape_configs:- job_name: 'mysql'static_configs:- targets: ['your-mysql-server-ip:9104']
3. 监控 Redis 数据库
3.1 安装并配置 redis_exporter
从 redis_exporter 发布页面 下载适合你系统的版本并解压。
启动 redis_exporter:
bash
./redis_exporter --redis.addr redis://your-redis-server-ip:port
3.2 配置 Prometheus 监控 Redis
在 prometheus.yml 中添加以下配置:
yaml
scrape_configs:- job_name: 'redis'static_configs:- targets: ['your-redis-exporter-ip:9121']
4. 监控 MongoDB 数据库
4.1 安装并配置 mongodb_exporter
从 mongodb_exporter 发布页面 下载适合你系统的版本并解压。
启动 mongodb_exporter:
bash
./mongodb_exporter --mongodb.uri mongodb://your-mongodb-server-ip:port
4.2 配置 Prometheus 监控 MongoDB
在 prometheus.yml 中添加以下配置:
yaml
scrape_configs:- job_name: 'mongodb'static_configs:- targets: ['your-mongodb-exporter-ip:9216']
5. 配置 Grafana
5.1 添加 Prometheus 数据源
登录 Grafana(http://your-grafana-server-ip:3000),进入 Configuration -> Data Sources,选择 Prometheus,填写 Prometheus 的 URL(如 http://your-prometheus-server-ip:9090),然后保存并测试连接。
5.2 导入仪表盘
你可以从 Grafana 的 仪表盘库 导入预定义的仪表盘:
- Spring Boot 应用:可以使用 ID 为
13978的仪表盘。 - MySQL 数据库:使用 ID 为
7362的仪表盘。 - Redis 数据库:使用 ID 为
11835的仪表盘。 - MongoDB 数据库:使用 ID 为
10577的仪表盘。
在 Grafana 中点击 + -> Import,输入相应的仪表盘 ID,选择数据源后导入即可。
6. 验证与优化
6.1 验证 Prometheus 采集
访问 http://your-prometheus-server-ip:9090/targets,确保所有监控目标的状态为 UP。
6.2 验证 Grafana 展示
在 Grafana 中查看导入的仪表盘,确认数据正常展示。
6.3 优化建议
- 调整
scrape_interval以平衡数据采集频率和性能开销。 - 配置
storage.tsdb.retention.time控制数据保留时长。
相关文章:
基于 Prometheus + Grafana 监控微服务和数据库
以下是基于 Prometheus Grafana 监控微服务和数据库的详细指南,包含架构设计、安装配置及验证步骤: 一、整体架构设计 二、监控微服务 1. 微服务指标暴露 Spring Boot 应用: xml <!-- 添加 Micrometer 依赖 --> <dependency>…...
GitHub Copilot 在 VS Code 上的终极中文指南:从安装到高阶玩法
GitHub Copilot 在 VS Code 上的终极中文指南:从安装到高阶玩法 前言 GitHub Copilot 作为 AI 编程助手,正在彻底改变开发者的编码体验。本文将针对中文开发者,深度解析如何在 VS Code 中高效使用 Copilot,涵盖基础设置、中文优化…...
为什么选择 Rust 和 WebAssembly?
一、低级控制与高级体验 在 Web 应用开发中,JavaScript 虽然灵活,但往往难以保证稳定的性能。其动态类型系统和垃圾回收(GC)机制会导致性能波动,甚至在不经意间因偏离 JIT(即时编译器)的最佳路…...
Vala语言基础知识-源文件和编译
源文件和编译 Vala代码以.vala为扩展名。与Java等语言不同,Vala不强制要求严格的文件结构——它没有类似Java的"包"(package)或"类文件"(class file)的概念,而是通过文件内的文本…...
CAN总线的CC帧和FD帧之间如何仲裁
为满足CAN总线日益提高的带宽需求,博世公司于2012年推出CAN FD(具有灵活数据速率的CAN)标准,国际标准化组织(ISO)2015年通过ISO 11898-1:2015标准,正式将CAN FD纳入国际标准,以示区别…...
SpringBoot 第一课(Ⅲ) 配置类注解
目录 一、PropertySource 二、ImportResource ①SpringConfig (Spring框架全注解) ②ImportResource注解实现 三、Bean 四、多配置文件 多Profile文件的使用 文件命名约定: 激活Profile: YAML文件支持多文档块ÿ…...
Python的类和对象(4)
1、反射 动态的给类和对象添加属性,获取属性,删除属性,修改属性【反射】。 --4个内置函数 1)设置属性:setattr( 对象/类,属性名,属性值) 2)获取属性:getattr(对象/类&am…...
使用EasyExcel进行简单的导入、导出
准备 在pom.xml添加依赖 <!-- EasyExcel --><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.1.1</version></dependency>导入 controller // 用户导入Operation(summary…...
Excel(函数篇):COUNTIF与CONUTIFS函数、SUMIF与SUMIFS函数、ROUND函数、MATCH与INDEX函数、混合引用与条件格式
目录 COUNTIF和COUNTIFS函数COUNTIF函数COUNTIFS函数SUMIF和SUMIFS函数SUMIF函数SUMIFS函数SUMIFS函数与控件实现动态年月汇总ROUND、ROUNDUP、ROUNDDOWN函数单元格混合引用条件格式与公式,标记整行数据MATCH和INDEX函数COUNTIF和COUNTIFS函数 COUNTIF函数 统计下“苏州”出现…...
虚拟定位 1.2.0.2 | 虚拟定位,上班打卡,校园跑步模拟
Fake Location是一款运行于安卓平台上的功能强大、简单实用的虚拟定位软件。它能够帮助用户自定义位置到地图上的任意地方,以ROOT环境运行不易被检测,同时也支持免ROOT运行。提供路线模拟、步频模拟、WIFI模拟等方式,支持反检测。 大小&…...
【最大异或和——可持久化Trie】
题目 代码 #include <bits/stdc.h> using namespace std;const int N 6e510; //注意这里起始有3e5,又可能插入3e5 const int M N * 25;int rt[N], tr[M][2]; //根,trie int idx, cnt, br[M]; //根分配器,点分配器,点的相…...
C# WPF编程-启动新窗口
C# WPF编程-启动新窗口 新建窗口: 工程》添加》窗口 命名并添加新的窗口 这里窗口名称为Window1.xaml 启动新窗口 Window1 win1 new Window1(); win1.Show(); // 非模态启动窗口win1.ShowDialog(); // 模态启动窗口 模态窗口:当一个模态窗口被打开时&a…...
数据库:MySQL 指令大全(备忘清单)
文章目录 入门介绍登录MySQL常用的数据库 Database表 TableProccess 查看 MySQL 信息退出MySQL会话备份 MySQL 示例管理表格从表中查询数据从多个表查询使用 SQL 约束修改数据管理视图管理触发器WHENEVENTTRIGGER_TYPE 管理索引 MySQL 数据类型StringsDate & timeNumeric 函…...
NET进行CAD二次开发之二
本文主要针对CAD 二次开发入门与实践:以 C# 为例_c# cad-CSDN博客的一些实践问题做一些补充。 一、DLL介绍 在 AutoCAD 中,accoremgd.dll、acdbmgd.dll 和 acmgd.dll 都是与.NET API 相关的动态链接库,它们在使用.NET 语言(如 C#、VB.NET)进行 AutoCAD 二次开发时起着关…...
Python 实现大文件的高并发下载
项目背景 基于一个 scrapy-redis 搭建的分布式系统,所有item都通过重写 pipeline 存储到 redis 的 list 中。这里我通过代码演示如何基于线程池 协程实现对 item 的中文件下载。 Item 结构 目的是为了下载 item 中 attachments 保存的附件内容。 {"crawl_tim…...
【最新】 ubuntu24安装 1panel 保姆级教程
系统:ubuntu24.04.1 安装软件 :1panel 第一步:更新系统 sudo apt update sudo apt upgrade 如下图 第二步:安装1panel,运行如下命令 curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o …...
c++图论(二)之图的存储图解
在 C 中实现图的存储时,常用的方法包括 邻接矩阵(Adjacency Matrix)、邻接表(Adjacency List) 和 边列表(Edge List)。以下是具体实现方法、优缺点分析及代码示例: 1. 邻接矩阵&…...
c++图论(一)之图论的起源和图的概念
C 图论之图论的起源和图的概念 图论(Graph Theory)是数学和计算机科学中的一个重要分支,其起源可以追溯到 18 世纪 的经典问题。以下是图论的历史背景、核心起源问题及其与基本概念和用途: 借用一下CSDN的图片哈 一、图论的起源&…...
《Python深度学习》第二讲:深度学习的数学基础
本讲来聊聊深度学习的数学基础。 深度学习听起来很厉害,其实它背后是一些很有趣的数学原理。本讲会用简单的方式解释这些原理,还会用一些具体的例子来帮助你理解。 2.1 初识神经网络 先从一个简单的任务开始:识别手写数字。 想象一下,你有一堆手写数字的图片,你想让计算…...
ChatGPT and Claude国内使用站点
RawChat kelaode chatgptplus chatopens(4.o mini免费,plus收费) 网页: 定价: wildcard 网页: 虚拟卡定价: 2233.ai 网页: 定价: MaynorAPI chatgpt cla…...
进行性核上性麻痹:精心护理,点亮希望之光
进行性核上性麻痹是一种罕见的神经退行性疾病,严重影响患者的生活质量。有效的健康护理能够在一定程度上缓解症状、延缓病情发展,给患者带来更好的生活体验。 在日常生活护理方面,由于患者平衡能力逐渐下降,行动不便,居…...
ZED X系列双目3D相机的耐用性与创新设计解析
在工业自动化和学术研究领域,高精度的视觉设备正成为提升效率和质量的关键。ZED X系列AI立体相机,凭借其先进的技术和耐用的设计,为这一领域带来了新的可能。 核心技术:深度感知与精准追踪 ZED X系列的核心技术之一是Neural Dept…...
HarmonyOS三层架构实战
目录: 1、三层架构项目结构1.0、三层架构简介1.1、 common层(主要放一些公共的资源等)1.2、 features层(主要模块定义的组件以及图片等静态资源)1.3、 products层(主要放主页面层和一些主要的资源ÿ…...
计算机四级 - 数据库原理 - 第4章 「关系数据库标准语言SQL」
4.1 SQL概述 4.1.1 结构化查询语言SQL SQL(Structured Query Language)称为结构化查询语言,它是由1974年由Boyce和Chamberi提出的,1975年至1979年IBM公司的San Jose Research Laboratory研制了关系数据库管理系统的原型系统System R,并实现了这种语198…...
基于PMU的14节点、30节点电力系统状态估计MATLAB程序
“电气仔推送”获得资料(专享优惠) 程序简介: 程序采用三种方法对14节点和30节点电力系统状态进行评估: ①PMU同步向量测量单元结合加权最小二乘法(WLS)分析电力系统的电压幅值和相角状态; …...
JS超过Number的最大值
场景:用户输入(这个可以通过前端限制输入长度控制)或正规场景,大数据量展示 Number类型的最大值是2^53 - 1 解决方案一:BigInt BigInt 是 JavaScript 中专门用来表示任意精度整数的类型。它允许你处理超出 Number 范围的整数。 const bigNu…...
Deepseek API+Python测试用例一键生成与导出-V1.0.2【实现需求文档图片识别与用例生成自动化】
在测试工作中,需求文档中的图片(如界面设计图、流程图)往往是测试用例生成的重要参考。然而,手动提取图片并识别内容不仅耗时,还容易出错。本文将通过一个自研小工具,结合 PaddleOCR 和大模型,自…...
整形在内存中的存储(例题逐个解析)
目录 一.相关知识点 1.截断: 2.整形提升: 3.如何 截断,整型提升? (1)负数 (2)正数 (3)无符号整型,高位补0 注意:提升后得到的…...
基于变分推理与 Best‑of‑N 策略的元 Prompt 自动生成与优化框架
摘要 本文提出了一种融合变分推理与 Best‑of‑N 策略的元 Prompt 自动生成与优化框架,通过高度参数化的模板、随机扰动采样及多指标评分机制,实现从初始提示生成到最终输出的动态优化。同时,针对实际应用中对自适应参数调整、深层语义理解、…...
AI 技术在智慧农业中的应用实践
智慧农业是通过现代信息技术(如物联网、大数据、人工智能等)提升农业生产效率、降低资源消耗、改善农产品质量的现代农业模式。AI 技术在智慧农业中的应用实践涵盖了从种植到收获的全流程,以下是具体的方案和应用场景: 1. AI 在智慧农业中的应用场景 1.1 精准种植 应用场景…...
