Prometheus + Grafana 搭建应用监控体系

在进行系统压测前,需要监控程序情况。今天实践了通过 Prometheus + Grafana 搭建应用监控体系,为后续使用 JMeter 对营销系统抽奖接口进行压测做准备。其中 Prometheus 主要负责指标数据的采集与存储,而 Grafana 则专注于数据的可视化展示。

一、应用端监控配置

首先需要在应用程序中集成监控采集能力,让 Spring Boot 应用能够暴露指标数据供 Prometheus 抓取。

1. 添加依赖

pom.xml 中添加以下依赖:

复制代码
<dependency>
    <groupId>io.micrometer</groupId>
    <artifactId>micrometer-registry-prometheus</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

2. 配置应用

application.yml 中启用监控端点:

复制代码
# 监控上报配置
management:
  endpoints:
    web:
      exposure:
        include: "*" # 暴露所有监控端点
  endpoint:
    health:
      show-details: always # 显示详细的健康检查信息
  metrics:
    export:
      prometheus:
        enabled: true # 启用Prometheus指标导出
  prometheus:
    enabled: true # 启用Prometheus专用端点

配置完成后,应用将在 /actuator/prometheus 路径暴露符合 Prometheus 格式的指标数据。

二、监控平台部署与配置

采用 Docker Compose 快速部署 Prometheus 和 Grafana,目录结构如下:

复制代码
data/
├─Grafana监控面板配置
│      New dashboard-1700969967327.json
│      README.md
│
└─monitor
    │  docker-compose.yml
    │
    └─etc
        ├─grafana
        │  └─provisioning
        │      └─datasources
        │              datasource.yml
        │
        └─prometheus
                prometheus.yml

1. Docker Compose 配置

yaml 复制代码
version: '3'
services:
  # 数据采集服务
  prometheus:
    image: swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/bitnami/prometheus:2.52.1
    container_name: prometheus
    restart: always
    ports:
      - 9090:9090
    volumes:
      - ./etc/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml
  
  # 数据可视化服务
  grafana:
    image: swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/grafana/grafana:latest
    container_name: grafana
    restart: always
    ports:
      - 4000:4000
    depends_on:
      - prometheus
    volumes:
      - ./etc/grafana:/etc/grafana

2. Prometheus 抓取配置

prometheus.yml 中配置应用监控目标:

yaml 复制代码
global:
  scrape_interval: 15s  # 抓取间隔

scrape_configs:
  - job_name: 'yfj-dev-tech'
    metrics_path: '/actuator/prometheus'
    static_configs:
      - targets: [ '192.168.31.12:8091' ]  # 替换为实际应用地址

3. 验证连接

启动服务后访问 192.168.31.250:9090,在 Targets 页面看到状态为 UP 表示配置成功。此时 Prometheus 已开始采集应用的各种运行指标,包括 JVM 内存、线程状态、HTTP 请求等。如需监控 JMeter 本身的性能数据,可参考相关插件配置(后续可扩展)。

4. Grafana 可视化配置

访问 192.168.31.250:4000 进入 Grafana,配置数据源指向 Prometheus 后即可创建监控面板。通过导入 JSON 配置或使用 AI 辅助生成,可以快速搭建包含 Tomcat 线程数、数据库连接数、接口响应时间等关键指标的监控视图。

三、后续计划

至此,基础监控环境已搭建完成。下一步将基于此监控体系,使用 JMeter 对营销系统抽奖接口进行压测,通过实时监控指标变化来分析系统性能瓶颈,为优化提供数据支撑。

监控体系的建立不仅服务于本次压测,更为后续的系统稳定性保障和性能优化建立了可持续的观测能力。

相关推荐
_F_y13 小时前
C++重点知识总结
java·jvm·c++
打工的小王13 小时前
Spring Boot(三)Spring Boot整合SpringMVC
java·spring boot·后端
毕设源码-赖学姐13 小时前
【开题答辩全过程】以 高校体育场馆管理系统为例,包含答辩的问题和答案
java·spring boot
我真会写代码13 小时前
SSM(指南一)---Maven项目管理从入门到精通|高质量实操指南
java·spring·tomcat·maven·ssm
vx_Biye_Design13 小时前
【关注可免费领取源码】房屋出租系统的设计与实现--毕设附源码40805
java·spring boot·spring·spring cloud·servlet·eclipse·课程设计
DN金猿14 小时前
接口路径正确,请求接口却提示404
java·tomcat
Maynor99614 小时前
OpenClaw 玩家必备:用 AI 自动追踪社区最新动态
java·服务器·人工智能
堕27414 小时前
java数据结构当中的《排序》(一 )
java·数据结构·排序算法
亓才孓14 小时前
[Class的应用]获取类的信息
java·开发语言
开开心心就好15 小时前
AI人声伴奏分离工具,离线提取伴奏K歌用
java·linux·开发语言·网络·人工智能·电脑·blender