基于 Prometheus + Grafana 监控微服务和数据库

news2025/3/18 14:08:31

以下是基于 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: prometheus
        metrics:
          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. 添加数据源
  1. 登录 Grafana(http://<服务器IP>:3000),进入 Configuration → Data Sources
  2. 选择 Prometheus,填写 URL(如 http://prometheus-server:9090),保存并测试连接。
2. 导入仪表盘
  • 微服务监控
    • 模板 ID:13978(Spring Boot 监控)
  • MySQL 监控
    • 模板 ID:7362(MySQL Overview)
  • Oracle 监控
    • 模板 ID:15222(Oracle Database Monitoring)
3. 自定义告警规则

在 Grafana 中创建告警规则(如数据库连接数阈值):

  1. 进入 Alerting → Rules,选择数据源。
  2. 编写 PromQL 查询,设置阈值和通知渠道(邮件 / Slack / 钉钉)。

五、验证与调优

  1. Prometheus 验证

    • 访问 http://prometheus-server:9090/targets,确保所有 Exporter 状态为 UP
    • 使用 PromQL 查询指标(如 node_cpu_seconds_total)。
  2. Grafana 验证

    • 检查仪表盘数据是否实时更新。
    • 测试告警规则是否触发通知。
  3. 性能优化

    • 调整 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: prometheus
  metrics:
    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 控制数据保留时长。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2317260.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CAN总线的CC帧和FD帧之间如何仲裁

为满足CAN总线日益提高的带宽需求&#xff0c;博世公司于2012年推出CAN FD&#xff08;具有灵活数据速率的CAN&#xff09;标准&#xff0c;国际标准化组织&#xff08;ISO&#xff09;2015年通过ISO 11898-1:2015标准&#xff0c;正式将CAN FD纳入国际标准&#xff0c;以示区别…

SpringBoot 第一课(Ⅲ) 配置类注解

目录 一、PropertySource 二、ImportResource ①SpringConfig &#xff08;Spring框架全注解&#xff09; ②ImportResource注解实现 三、Bean 四、多配置文件 多Profile文件的使用 文件命名约定&#xff1a; 激活Profile&#xff1a; YAML文件支持多文档块&#xff…

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是一款运行于安卓平台上的功能强大、简单实用的虚拟定位软件。它能够帮助用户自定义位置到地图上的任意地方&#xff0c;以ROOT环境运行不易被检测&#xff0c;同时也支持免ROOT运行。提供路线模拟、步频模拟、WIFI模拟等方式&#xff0c;支持反检测。 大小&…

【最大异或和——可持久化Trie】

题目 代码 #include <bits/stdc.h> using namespace std;const int N 6e510; //注意这里起始有3e5&#xff0c;又可能插入3e5 const int M N * 25;int rt[N], tr[M][2]; //根&#xff0c;trie int idx, cnt, br[M]; //根分配器&#xff0c;点分配器&#xff0c;点的相…

C# WPF编程-启动新窗口

C# WPF编程-启动新窗口 新建窗口&#xff1a; 工程》添加》窗口 命名并添加新的窗口 这里窗口名称为Window1.xaml 启动新窗口 Window1 win1 new Window1(); win1.Show(); // 非模态启动窗口win1.ShowDialog(); // 模态启动窗口 模态窗口&#xff1a;当一个模态窗口被打开时&a…

Python 实现大文件的高并发下载

项目背景 基于一个 scrapy-redis 搭建的分布式系统&#xff0c;所有item都通过重写 pipeline 存储到 redis 的 list 中。这里我通过代码演示如何基于线程池 协程实现对 item 的中文件下载。 Item 结构 目的是为了下载 item 中 attachments 保存的附件内容。 {"crawl_tim…

【最新】 ubuntu24安装 1panel 保姆级教程

系统&#xff1a;ubuntu24.04.1 安装软件 &#xff1a;1panel 第一步&#xff1a;更新系统 sudo apt update sudo apt upgrade 如下图 第二步&#xff1a;安装1panel&#xff0c;运行如下命令 curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o …

c++图论(二)之图的存储图解

在 C 中实现图的存储时&#xff0c;常用的方法包括 邻接矩阵&#xff08;Adjacency Matrix&#xff09;、邻接表&#xff08;Adjacency List&#xff09; 和 边列表&#xff08;Edge List&#xff09;。以下是具体实现方法、优缺点分析及代码示例&#xff1a; 1. 邻接矩阵&…

c++图论(一)之图论的起源和图的概念

C 图论之图论的起源和图的概念 图论&#xff08;Graph Theory&#xff09;是数学和计算机科学中的一个重要分支&#xff0c;其起源可以追溯到 18 世纪 的经典问题。以下是图论的历史背景、核心起源问题及其与基本概念和用途&#xff1a; 借用一下CSDN的图片哈 一、图论的起源&…

ChatGPT and Claude国内使用站点

RawChat kelaode chatgptplus chatopens&#xff08;4.o mini免费&#xff0c;plus收费&#xff09; 网页&#xff1a; 定价&#xff1a; wildcard 网页&#xff1a; 虚拟卡定价&#xff1a; 2233.ai 网页&#xff1a; 定价&#xff1a; MaynorAPI chatgpt cla…

进行性核上性麻痹:精心护理,点亮希望之光

进行性核上性麻痹是一种罕见的神经退行性疾病&#xff0c;严重影响患者的生活质量。有效的健康护理能够在一定程度上缓解症状、延缓病情发展&#xff0c;给患者带来更好的生活体验。 在日常生活护理方面&#xff0c;由于患者平衡能力逐渐下降&#xff0c;行动不便&#xff0c;居…

ZED X系列双目3D相机的耐用性与创新设计解析

在工业自动化和学术研究领域&#xff0c;高精度的视觉设备正成为提升效率和质量的关键。ZED X系列AI立体相机&#xff0c;凭借其先进的技术和耐用的设计&#xff0c;为这一领域带来了新的可能。 核心技术&#xff1a;深度感知与精准追踪 ZED X系列的核心技术之一是Neural Dept…

HarmonyOS三层架构实战

目录&#xff1a; 1、三层架构项目结构1.0、三层架构简介1.1、 common层&#xff08;主要放一些公共的资源等&#xff09;1.2、 features层&#xff08;主要模块定义的组件以及图片等静态资源&#xff09;1.3、 products层&#xff08;主要放主页面层和一些主要的资源&#xff…

计算机四级 - 数据库原理 - 第4章 「关系数据库标准语言SQL」

4.1 SQL概述 4.1.1 结构化查询语言SQL SQL(Structured Query Language)称为结构化查询语言&#xff0c;它是由1974年由Boyce和Chamberi提出的&#xff0c;1975年至1979年IBM公司的San Jose Research Laboratory研制了关系数据库管理系统的原型系统System R,并实现了这种语198…

基于PMU的14节点、30节点电力系统状态估计MATLAB程序

“电气仔推送”获得资料&#xff08;专享优惠&#xff09; 程序简介&#xff1a; 程序采用三种方法对14节点和30节点电力系统状态进行评估&#xff1a; ①PMU同步向量测量单元结合加权最小二乘法&#xff08;WLS&#xff09;分析电力系统的电压幅值和相角状态&#xff1b; …

Deepseek API+Python测试用例一键生成与导出-V1.0.2【实现需求文档图片识别与用例生成自动化】

在测试工作中&#xff0c;需求文档中的图片&#xff08;如界面设计图、流程图&#xff09;往往是测试用例生成的重要参考。然而&#xff0c;手动提取图片并识别内容不仅耗时&#xff0c;还容易出错。本文将通过一个自研小工具&#xff0c;结合 PaddleOCR 和大模型&#xff0c;自…

整形在内存中的存储(例题逐个解析)

目录 一.相关知识点 1.截断&#xff1a; 2.整形提升&#xff1a; 3.如何 截断&#xff0c;整型提升&#xff1f; &#xff08;1&#xff09;负数 &#xff08;2&#xff09;正数 &#xff08;3&#xff09;无符号整型&#xff0c;高位补0 注意&#xff1a;提升后得到的…

蓝牙系统的核心组成解析

一、硬件层&#xff1a;看得见的物理载体 1. 射频模块&#xff08;Radio Frequency Module&#xff09; 专业描述&#xff1a;工作在2.4GHz ISM频段&#xff0c;支持GFSK/π/4 DQPSK/8DPSK调制方式 功能类比&#xff1a;相当于人的"嘴巴"和"耳朵" 发射端…

uniapp笔记-底部和首部标签页菜单生成

逻辑 这些都是需要配置pages.json文件。 其中底部需要手动配置tarBar&#xff0c;如&#xff1a; "tabBar": {"list":[{"pagePath": "pages/index/index","text": "首页"},{"pagePath": "pages/…