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 对营销系统抽奖接口进行压测,通过实时监控指标变化来分析系统性能瓶颈,为优化提供数据支撑。

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

相关推荐
码农的小菜园3 小时前
Java线程池学习笔记
java·笔记·学习
sleP4o3 小时前
[Docker] ‘s Basic Usage
docker·容器·eureka
清汤饺子3 小时前
搞懂 Cursor 后,我一行代码都不敲了《实战篇》
前端·javascript·后端
hongtianzai3 小时前
Laravel8.x核心特性全解析
java·c语言·开发语言·golang·php
AntBlack3 小时前
Ant-Browser : 发布一个开源免费的指纹浏览器 ,欢迎体验
后端·架构·go
逸Y 仙X3 小时前
文章十一:ElasticSearch Dynamic Template详解
java·大数据·数据库·elasticsearch·搜索引擎·全文检索
隔壁小邓3 小时前
IDEA 中同时启动多个微服务
java·微服务·intellij-idea
Yu_摆摆3 小时前
windows部署prometheus+windows_exporter+grafana+alertmanager实现监控CPU、内存、磁盘并邮件告警
windows·grafana·prometheus
:1213 小时前
idea17创建tomcat项目(计网底层核心理解!)
java·ide·intellij-idea
楼田莉子3 小时前
C++高性能并发内存池:三种Cache的设计及其内存申请释放
c++·后端·链表·哈希算法·visual studio