Docker 部署 Prometheus 和 Grafana 监控 Spring Boot 服务

简介: Docker 部署 Prometheus 和 Grafana 监控 Spring Boot 服务实现步骤

一、Spring Boot 服务端配置

  • 引入依赖:在 Spring Boot 项目的 pom.xml 文件中引入以下依赖:
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
    <groupId>io.micrometer</groupId>
    <artifactId>micrometer-registry-prometheus</artifactId>
</dependency>
  • 配置文件:在 application.properties 或 application.yml 文件中添加以下配置:
management.endpoints.web.exposure.include=prometheus,health
management.metrics.export.prometheus.enabled=true
  • 启动服务:启动 Spring Boot 服务后,访问 http://:<端口>/actuator/prometheus,若能正常返回监控指标数据,则说明配置成功。

二、部署 Prometheus

  • 下载镜像
docker pull prom/prometheus:latest
  • 创建配置文件:在本地创建 prometheus.yml 文件,内容如下:
global:
  scrape_interval: 15s
  evaluation_interval: 15s

scrape_configs:
  - job_name: 'prometheus'
    static_configs:
      - targets: ['localhost:9090']
  - job_name: 'springboot'
    metrics_path: '/actuator/prometheus'
    static_configs:
      - targets: ['<Spring Boot服务IP>:<端口>']
  • 启动 Prometheus
docker run -d -p 9090:9090 --name prometheus \
    -v $(pwd)/prometheus.yml:/etc/prometheus/prometheus.yml \
    prom/prometheus:latest

三、部署 Grafana

  • 下载镜像
docker pull grafana/grafana:latest
  • 运行 Grafana
docker run -d -p 3000:3000 --name=grafana \
    grafana/grafana:latest
  • 访问 Grafana:通过浏览器访问 http://<服务器IP>:3000,默认用户名和密码均为 admin,登录后需修改密码。

  • 添加数据源

    • 点击左侧菜单栏的 “Connections” 图标。
    • 在数据源列表中找到 “prometheus” 图标或通过搜索框输入 “prometheus” 搜索。
    • 点击 “prometheus” 图标,进入数据源页面。
    • 点击页面右上角蓝色的 “Add new data source” 按钮,添加数据源。
    • 填写 Prometheus server URL(例如,http://<服务器IP>:9090)。
    • 根据需要调整其他数据源设置(例如,认证或请求方法等)。
    • 点击 “Save & Test” 按钮,若弹出 “Data source is working” 则说明配置成功。
  • 导入监控模板
    • 点击左侧菜单栏的 “+” 号,选择 “Import”。
    • 输入模板 ID(如 10280),点击 “Load” 加载模板。
    • 点击 “Import” 导入模板,即可查看 Spring Boot 服务的监控数据。

四、注意事项

  • 确保 Spring Boot 服务的 IP 地址和端口在 Prometheus 配置文件中正确填写,且服务能够正常访问。
  • 若使用的是云服务器,需确保相关端口已在云服务器的防火墙和安全组规则中开放。
  • Prometheus 和 Grafana 的版本可根据实际情况选择,但需保证版本间的兼容性。
目录
相关文章
|
4月前
|
应用服务中间件 网络安全 nginx
手把手教你使用 Docker 部署 Nginx 教程
本文详解Nginx核心功能与Docker部署优势,涵盖镜像拉取、容器化部署(快速、挂载、Compose)、HTTPS配置及常见问题处理,助力高效搭建稳定Web服务。
1842 4
|
6月前
|
运维 Devops 持续交付
揭秘 Docker 自动部署神器 Websoft9:热门开源软件一键部署
在企业IT建设中,软件部署常面临效率低、易出错等问题。通过Docker与自动化工具,可实现高效、标准化和可追溯的部署流程,提升企业应用交付效率,降低运维门槛,助力中小企业实现自动化部署。
400 5
揭秘 Docker 自动部署神器 Websoft9:热门开源软件一键部署
|
5月前
|
Prometheus 监控 Cloud Native
基于docker搭建监控系统&日志收集
Prometheus 是一款由 SoundCloud 开发的开源监控报警系统及时序数据库(TSDB),支持多维数据模型和灵活查询语言,适用于大规模集群监控。它通过 HTTP 拉取数据,支持服务发现、多种图表展示(如 Grafana),并可结合 Loki 实现日志聚合。本文介绍其架构、部署及与 Docker 集成的监控方案。
503 122
基于docker搭建监控系统&日志收集
|
5月前
|
JavaScript 算法 前端开发
【Docker项目实战】使用Docker部署paopao-ce微社区
【Docker项目实战】使用Docker部署paopao-ce微社区
476 84
【Docker项目实战】使用Docker部署paopao-ce微社区
|
6月前
|
运维 Cloud Native 开发者
Docker:现代化应用开发与部署的神器
Docker:现代化应用开发与部署的神器
271 101
|
6月前
|
设计模式 Linux 开发工具
Docker部署会吗?
本段内容主要介绍了Docker常用命令、Linux基础指令及日志查看方法,还涉及SpringMVC的执行流程、设计模式与注解,适合用于面试中技术能力的展示。
170 0
|
4月前
|
应用服务中间件 Linux nginx
在虚拟机Docker环境下部署Nginx的步骤。
以上就是在Docker环境下部署Nginx的步骤。需要注意,Docker和Nginix都有很多高级用法和细节需要掌握,以上只是一个基础入门级别的教程。如果你想要更深入地学习和使用它们,请参考官方文档或者其他专业书籍。
213 5