Spring Boot微服务架构(八):开发之初就引入APM工具监控

news2025/6/3 21:59:35

使用 APM(Application Performance Management)工具监控 Spring Boot 应用,可以帮助开发者实时追踪性能瓶颈、分析调用链路、监控资源使用情况,并快速定位故障。以下是详细的步骤和常用工具的选择指南:


​一、常用 APM 工具及特点​

工具名称类型特点
​SkyWalking​分布式追踪 + 指标监控开源、支持 Java Agent、自动链路追踪、可视化仪表盘
​Zipkin​分布式追踪轻量级、需手动埋点、适合简单场景
​Prometheus​指标监控多维数据模型、灵活告警、结合 Grafana 可视化
​Elastic APM​全链路监控基于 OpenTelemetry,集成日志、指标、链路追踪,适合 Elastic 生态
​New Relic​商业全栈监控功能全面、支持多语言、商业版功能强大
​Datadog​云原生监控支持 APM、基础设施监控、日志,适合混合云环境

​二、监控 Spring Boot 的核心步骤​

​1. 指标监控(Metrics)​

​目标​​:监控 JVM、HTTP 请求、数据库连接池等指标。
​工具​​:Spring Boot Actuator + Prometheus + Grafana
​步骤​​:

  1. ​添加依赖​​(pom.xml):

    <!-- Actuator 暴露指标 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
    <!-- Micrometer Prometheus 导出器 -->
    <dependency>
        <groupId>io.micrometer</groupId>
        <artifactId>micrometer-registry-prometheus</artifactId>
    </dependency>
  2. ​配置 application.yml​:

    management:
      endpoints:
        web:
          exposure:
            include: prometheus, health  # 暴露 Prometheus 和健康检查端点
      metrics:
        export:
          prometheus:
            enabled: true
  3. ​启动应用​​,访问 http://localhost:8080/actuator/prometheus,可以看到暴露的指标数据。

  4. ​部署 Prometheus​​:配置抓取目标(指向 Spring Boot 的 /actuator/prometheus 端点)。

  5. ​使用 Grafana 可视化​​:导入 Spring Boot 的仪表盘模板(如 Grafana Spring Boot Dashboard)。


​2. 分布式链路追踪(Tracing)​

​目标​​:追踪微服务间的调用链路,分析请求耗时。
​工具​​:SkyWalking、Zipkin、Elastic APM
​以 SkyWalking 为例​​:

  1. ​下载 SkyWalking Agent​​:从 官网 获取 JAR 包。
  2. ​启动 Spring Boot 应用时附加 Agent​​:
    java -javaagent:/path/to/skywalking-agent.jar \
         -Dskywalking.agent.service_name=my-spring-boot-app \
         -Dskywalking.collector.backend_service=127.0.0.1:11800 \
         -jar your-application.jar
  3. ​访问 SkyWalking UI​​(默认 http://localhost:8080),查看链路追踪和性能分析。

​3. 日志与错误监控​

​目标​​:关联日志与链路追踪,捕获异常和错误。
​工具​​:ELK Stack(Elasticsearch + Logstash + Kibana)、Loki + Grafana
​步骤​​:

  1. ​在 Spring Boot 中集成 Logback 或 Log4j2​​,添加 Trace ID 到日志中(通过 SkyWalking 或 Sleuth 自动注入)。
  2. ​配置日志输出到 Elasticsearch/Loki​​:使用 Filebeat 或 Fluentd 收集日志。
  3. ​通过 Kibana/Loki Dashboard 分析日志​​,结合链路追踪快速定位问题。

​4. 商业工具集成(可选)​

​New Relic​​:

  1. ​添加 Java Agent​​:下载 New Relic Java Agent。
  2. ​配置 newrelic.yml​:设置 License Key 和应用名称。
  3. ​启动应用​​:通过 -javaagent 参数加载 Agent。
  4. ​在 New Relic 控制台​​查看应用性能数据。

​三、关键监控指标​

  1. ​JVM 指标​​:堆内存、GC 时间、线程状态。
  2. ​HTTP 请求​​:响应时间、错误率、QPS。
  3. ​数据库​​:慢查询、连接池使用率。
  4. ​外部服务调用​​:Feign/RestTemplate 的耗时和成功率。
  5. ​系统资源​​:CPU、内存、磁盘 I/O。

​四、最佳实践​

  1. ​合理配置采样率​​:避免链路追踪数据量过大(如 Zipkin 可设置 spring.sleuth.sampler.probability=0.1)。
  2. ​设置告警规则​​:在 Prometheus 或 Grafana 中配置阈值告警(如 HTTP 5xx 错误率 > 1%)。
  3. ​结合日志与链路​​:通过 Trace ID 关联日志和调用链,快速定位问题根源。
  4. ​定期优化​​:根据监控数据优化慢查询、调整 JVM 参数、扩容资源。

​五、工具选择建议​

  • ​简单场景​​:Spring Boot Actuator + Prometheus + Grafana(免费、轻量)。
  • ​分布式追踪​​:SkyWalking(国产开源,社区活跃)或 Zipkin(轻量级)。
  • ​全栈监控​​:Elastic APM(集成日志、指标、链路)或 New Relic(商业级功能)。
  • ​云原生环境​​:Datadog 或 Prometheus + Grafana(支持 Kubernetes 监控)。

通过以上步骤,可以实现对 Spring Boot 应用的全方位监控,快速发现性能瓶颈并提升系统稳定性。

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

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

相关文章

大规模真实场景 WiFi 感知基准数据集

一段话总结 本文提出CSI-Bench,首个大规模真实场景WiFi感知基准数据集,覆盖26个室内环境、35名用户、16种商用设备,包含461小时有效数据,支持跌倒检测、呼吸监测、定位、运动源识别等单任务及用户身份、活动、 proximity联合标注的多任务学习。通过标准化评估协议和基线模…

Python实现HPSO-TVAC优化算法优化支持向量机SVC分类模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在当今数据驱动的时代&#xff0c;支持向量机&#xff08;SVM&#xff09;作为一种经典的机器学习算法&#xff0c;…

ck-editor5的研究 (3):初步使用 CKEditor5 的事件系统和API

前言 在上一篇文章中—— ck-editor5的研究&#xff08;2&#xff09;&#xff1a;对 CKEditor5 进行设计&#xff0c;并封装成一个可用的 vue 组件 &#xff0c;我已经把 CKEditor5 封装成了一个通用vue组件&#xff0c;并且成功在nuxt中运行&#xff0c;并具备一定的通用性&…

WPS快速排版

论文包括&#xff08;按顺序&#xff09;&#xff1a;封面&#xff08;含题目&#xff09;、摘 要、关键词、Abstract&#xff08;英文摘要&#xff09;、Keywords、目录、正文、参考文献、在读期间发表的学术论文及研究成果&#xff0c;致 谢 题目&#xff08;黑小一加粗&…

Java实现命令行图书管理系统(附完整源码)

一、项目概述 本文将介绍如何使用Java实现一个基于命令行的图书管理系统。系统支持管理员和普通用户两种角色&#xff0c;提供图书的增删改查、借阅归还等功能。项目采用面向对象设计原则&#xff0c;代码结构清晰&#xff0c;适合Java初学者学习。 二、系统功能架构 graph T…

【数据结构】顺序表和链表详解(上)

前言&#xff1a;上期我们介绍了算法的复杂度&#xff0c;知道的算法的重要性同时也了解到了评判一个算法的好与坏就去看他的复杂度(主要看时间复杂度)&#xff0c;这一期我们就从顺序表和链表开始讲起。 文章目录 一&#xff0c;顺序表1&#xff0c;线性表2&#xff0c;顺序表…

唯创WT2606B TFT显示灵动方案,重构电子锁人机互动界面,赋能智能门锁全场景交互!

在智能家居的浪潮中&#xff0c;门锁搭载显示屏已成为行业创新的焦点。据行业数据显示&#xff0c;2023年全球智能门锁出货量中&#xff0c;搭载显示屏的型号占比已突破40%&#xff0c;且年复合增长率达25%。而2024年国内智能门锁销量突破2200万套&#xff0c;预计2025年市场规…

智能穿戴新标杆:SD NAND (贴片式SD卡)与 SOC 如何定义 AI 眼镜未来技术路径

目录 一、SD NAND&#xff1a;智能眼镜的“记忆中枢”突破空间限制的存储革命性能与可靠性的双重保障 二、SOC芯片&#xff1a;AI眼镜的“智慧大脑”从性能到能效的全面跃升多模态交互的底层支撑 三、SD NANDSOC&#xff1a;11&#xff1e;2的协同效应数据流水线的高效协同端侧…

node_modules包下载不下来

如果项目里面的package-lock.json有resolved &#xff0c;就指向了包的下载来源&#xff0c;如果这个网址挂了&#xff0c;那npm i 就会一直卡着。而且&#xff0c;在终端去修改 npm的镜像是没有用的 解决办法是:把项目里面的 lock文件 .npmrc都删了 然后重新下载就可以了

yolo个人深入理解

卷积层的理解,通过云端服务器训练模型,模型构建的重要性,针对极低像素的处理,模型训练召回率提高技巧,卷积层2,4,8,16,32的小模型与大模型的理解 一.关于backbone,neck,head深入理解 1,backbone的主要组成部分是sppf和conv,这是backbone的核心,其中yolov5和yolov8…

从0开始学vue:Element Plus详解

一、核心架构解析二、技术实现指南三、高级特性实现四、性能优化方案五、生态扩展方案六、调试与测试七、版本演进路线 Element Plus 是专为 Vue 3 设计的桌面端 UI 组件库&#xff0c;基于 Vue 3 的 Composition API 重构&#xff0c;在保持与 Element UI 兼容性的同时&#x…

互联网向左,区块链向右

2008年&#xff0c;中本聪首次提出了比特币的设想&#xff0c;这打开了去中心化的大门。 比特币白皮书清晰的描述了去中心化支付的解决方案&#xff0c;并分别从以下几个方面阐述了他的理念&#xff1a; 一、由转账双方点对点的通讯&#xff0c;而不通过中心化的第三方&#xf…

Python6.1打卡(day33)

DAY 33 MLP神经网络的训练 知识点回顾&#xff1a; 1.PyTorch和cuda的安装 2.查看显卡信息的命令行命令&#xff08;cmd中使用&#xff09; 3.cuda的检查 4.简单神经网络的流程 1.数据预处理&#xff08;归一化、转换成张量&#xff09; 2.模型的定义 …

论文阅读笔记——Quo Vadis, Action Recognition? A New Model and the Kinetics Dataset

I3D 论文 UCF-101&#xff08;13000多个视频&#xff09;和 HMDB-51&#xff08;7000多个视频&#xff09;数据集过小&#xff0c;提出了 Kinetics 数据集&#xff0c;并且在其之上预训练之后能够迁移到其他小的数据集。 2DLSTM&#xff1a;使用2D CNN的好处是可以直接从 Ima…

vscode编辑器怎么使用提高开发uVision 项目的效率,如何编译Keil MDK项目?

用vscode编译uVision 项目只需要安装一个Keil Assistant插件&#xff0c;即可用vscode开发“keil 项目”。极大提高开发速度&#xff01; 1.安装Keil Assistant插件 安装插件成功之后&#xff0c;应该会让安装一个东西&#xff0c;点击安装即可 2.配置安装包路径 3.打开 uVi…

AR测量工具:精准测量,多功能集成

在日常生活中&#xff0c;我们常常会遇到需要测量物体长度、距离或角度的情况。无论是装修房屋、制作家具&#xff0c;还是进行户外活动&#xff0c;一个精准的测量工具都能大大提高我们的工作效率。AR测量工具就是这样一款集多种功能于一体的实用测量软件&#xff0c;它利用增…

【Go-补充】Sync包

并发编程-Sync包 sync.WaitGroup 在代码中生硬的使用time.Sleep肯定是不合适的&#xff0c;Go语言中可以使用sync.WaitGroup来实现并发任务的同步。 sync.WaitGroup有以下几个方法&#xff1a; 方法名功能(wg * WaitGroup) Add(delta int)计数器delta(wg *WaitGroup) Done()…

设备驱动与文件系统:01 I/O与显示器

操作系统设备驱动学习之旅——以显示器驱动为例 从这一节开始&#xff0c;我要学习操作系统的第四个部分&#xff0c;就是i o设备的驱动。今天要讲的是第26讲&#xff0c;内容围绕i o设备中的显示器展开&#xff0c;探究显示器是如何被驱动的&#xff0c;也就是操作系统怎样让…

智慧充电桩数字化管理平台:环境监测与动态数据可视化技术有哪些作用?

随着新能源汽车的普及&#xff0c;智慧充电桩作为基础设施的重要组成部分&#xff0c;正逐步向数字化、智能化方向发展。环境监测与动态数据可视化技术的应用&#xff0c;为充电桩的高效管理和运维提供了全新解决方案。通过实时采集环境参数与运行数据&#xff0c;并结合可视化…

家政小程序开发,开启便捷生活新篇章

在快节奏的现代生活中&#xff0c;家务琐事常常让人分身乏术&#xff0c;如何高效解决家政服务需求成了众多家庭的难题。家政小程序开发&#xff0c;正是为解决这一痛点而生&#xff0c;它将为您带来前所未有的便捷生活体验。 想象一下&#xff0c;您只需打开手机上的家政小程…