Prometheus+Grafana实现Springboot服务监控

通过 Prometheus + Grafana 实现微服务监控是业界主流方案,核心流程是:Prometheus 采集微服务指标 → Grafana 可视化指标。以下是针对微服务架构的完整落地步骤,包括多服务监控、服务发现、告警配置等关键环节。

上一篇:
centos7部署 Prometheus 3.0.0 + Grafana 10.3.3 + Alertmanager 0.27.0

Spring Boot 3 集成 Prometheus 核心步骤,需要两组配置:

1.暴露 Prometheus 指标

添加maven依赖:

复制代码
<!-- Spring Boot Actuator(必须) -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

<!-- Micrometer Prometheus Registry(必须) -->
<dependency>
    <groupId>io.micrometer</groupId>
    <artifactId>micrometer-registry-prometheus</artifactId>
</dependency>

配置 application.yml :

添加配置:

复制代码
#prometheus 监控插件
management:
  endpoints:
    web:
      exposure:
        include: '*'
  metrics:
    export:
      prometheus:
        enabled: true
        rsocket:
          enabled: false  # 如果不需要RSocket支持可以禁用它
        step: 1m  # 指标的步长,可以根据需要调整
  endpoint:
    prometheus:
      enabled: true          # 确保启用(默认一般是 true)    

访问 Prometheus 指标接口:

复制代码
启动后,访问以下 URL(替换 IP 和端口):
http://<your-app>:<port>/actuator/prometheus

如果成功了 浏览器输出如下内容:

2.Prometheus 定时拉取:

在你的Prometheus 配置文件(prometheus.yml)中,添加一个 job,指向你的 Spring Boot 3 应用:

复制代码
scrape_configs:
  # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config.
  - job_name: "prometheus"
    # metrics_path defaults to '/metrics'
    # scheme defaults to 'http'.
    static_configs:
      - targets: ["localhost:9090"]

  - job_name: "ehr-hrwa-opt-service19" # Spring Boot 3 应用监控
    scrape_interval: 5s        # 采集间隔(默认15s,微服务建议缩短)
    metrics_path: '/actuator/prometheus'  # 指标接口路径
    static_configs:
      - targets: ["172.0.0.0:8081"]

如果是微服务多节点使用以下配置:

复制代码
  - job_name: 'ehr-hrwabat-service'  # 任务名称
    scrape_interval: 5s        # 采集间隔(默认15s,微服务建议缩短)
    metrics_path: '/management/prometheus'  # 指标接口路径
    static_configs:
      - targets:  # 微服务实例列表(IP:端口)
          - '172.1.16.13:5050'  # 服务1
          - '172.1.16.14:5050'  # 服务2
          - '172.1.16.15:5050'  # 服务3
          - '172.1.16.16:5050'  # 服务4
          - '172.1.16.17:5050'  # 服务5
          - '172.1.16.18:5050'  # 服务6

  - job_name: 'ehr-hrwa-opt-service'  # 任务名称
    scrape_interval: 5s        # 采集间隔(默认15s,微服务建议缩短)
    metrics_path: '/actuator/prometheus'  # 指标接口路径
    static_configs:
      - targets:  # 微服务实例列表(IP:端口)
          - '172.1.16.19:8080'  # 服务1
          - '172.1.16.20:8080'  # 服务2
          - '172.1.16.21:8080'  # 服务3
          - '172.1.16.22:8080'  # 服务4
          - '172.1.16.23:8080'  # 服务5
          - '172.1.16.24:8080'  # 服务6

替换yml文件后,重启prometheus :

复制代码
systemctl stop prometheus
systemctl start prometheus

在 Prometheus UI 中验证是否拉取成功:

复制代码
打开 Prometheus Web 界面:http://<prometheus-ip>:9090
进入 ​​Status → Targets​​
找到你配置的 job(如 ehr-hrwa-opt-service19)
查看对应 target(如 localhost:8080)的状态是否为 ​​UP​

集成 Grafana:

创建Grafana Dashboards 其实只有两步:

1.选择可视化面板的模板(load模板id),2.选择Prometheus 数据源。

复制代码
1.点击左侧菜单:​​Dashboards → Import​​
2.在弹窗中输入 ​​Dashboard ID​​(比如 7362)
3.选择你的 ​​Prometheus 数据源​​(确保已正确配置)
4.点击 ​​Import​​,Grafana 会自动加载该 Dashboard 模板

选择可视化面板的模板

访问grafana:http://localhost:3000/login

先添加数据源:

点击 配置按钮 -> Data sources -> Add data source

点击 "Add data source",选择 "Prometheus"

配置:

Name: Prometheus

URL: http://localhost:9090(或者你的 Prometheus 服务 IP:9090)

点击 "Save & Test",验证连接是否成功

点击 Dashboards -> Import 导入模板:

根据自己需要找对应的模板:12900(springboot综合监控,包括 HTTP、JVM、Tomcat、请求、错误等)、4701(JVM 相关指标:堆内存、GC、线程、类加载等)、7362(包括 HTTP 请求、状态码、延迟、错误等)​

最下面选择Prometheus 数据源:


点击导入:

加载Dashboards 成功以后如下:

prometheus.yml 中配置了几个job_name,这里就有几个应用:

点击保存 save Dashboards,保存可视化面板,方便以后使用。

1.在Grafana的Web界面中,点击左侧导航栏中的"Dashboard"。

  1. 在"Recently viewed dashboards"中,可以找到刚刚导入的监控模板。

  2. 点击模板,即可进入监控面板。

相关推荐
sg_knight1 天前
Spring 框架中的 SseEmitter 使用详解
java·spring boot·后端·spring·spring cloud·sse·sseemitter
Dolphin_Home1 天前
笔记:SpringBoot静态类调用Bean的2种方案(小白友好版)
java·spring boot·笔记
刘一说1 天前
Nacos 权限控制详解:从开源版 v2.2+ 到企业级安全实践
spring boot·安全·spring cloud·微服务·nacos·架构·开源
Q_Q5110082851 天前
python+django/flask+vue的大健康养老公寓管理系统
spring boot·python·django·flask·node.js
比奥利奥还傲.1 天前
无需复杂操作!Prometheus+cpolar+实现跨网监控自由
prometheus
czlczl200209251 天前
通过哪些条件确定用哪个消息转换器
spring boot
毕设源码-朱学姐1 天前
【开题答辩全过程】以 个人健康管理系统为例,包含答辩的问题和答案
java·spring boot
qq_12498707531 天前
基于微信小程序的线下点餐系统的设计与实现(源码+论文+部署+安装)
spring boot·微信小程序·小程序·毕业设计
IT_Octopus1 天前
Java GZip 压缩实践 +实践思考 +进一步压榨性能和存储方案思考:Protobuf+ GZip
java·spring boot
毕设源码-郭学长1 天前
【开题答辩全过程】以 高校教材大管家系统为例,包含答辩的问题和答案
java·spring boot