当前位置: 首页 > news >正文

Spring Boot - 通过ServletRequestHandledEvent事件实现接口请求的性能监控

文章目录

  • 概述
  • 1. `ServletRequestHandledEvent`事件
  • 2. 实现步骤
  • 3. 优缺点分析
  • 4. 测试与验证
  • 小结
  • 其他方案
    • 1. 自定义拦截器
    • 2. 性能监控平台
    • 3. 使用Spring Boot Actuator
    • 4. APM工具

在这里插入图片描述


概述

在Spring框架中,监控接口请求的性能可以通过ServletRequestHandledEvent事件实现。这种方法简单有效,能够帮助开发者实时跟踪和分析请求的性能。


1. ServletRequestHandledEvent事件

ServletRequestHandledEvent是Spring中的一个事件类,它在请求处理完成后发布,包含了请求的详细信息,如客户端地址、请求URL、请求方法和处理时间。使用这个事件可以轻松地监控和记录每个请求的性能数据。


2. 实现步骤

下面是如何通过TimeCountListener实现接口请求性能监控的步骤:

  1. 创建监听器类

    实现ApplicationListener<ServletRequestHandledEvent>接口并覆盖onApplicationEvent方法:

    @Component
    public class TimeCountListener implements ApplicationListener<ServletRequestHandledEvent> {@Overridepublic void onApplicationEvent(ServletRequestHandledEvent event) {Throwable failureCause = event.getFailureCause();if (failureCause != null) {System.err.printf("错误原因: %s%n", failureCause.getMessage());}System.err.println("========================================");System.err.printf("请求客户端地址:%s\n请求URL: %s\n请求Method: %s\n请求耗时: %d毫秒%n", event.getClientAddress(),event.getRequestUrl(), event.getMethod(), event.getProcessingTimeMillis());System.err.println("========================================");}
    }
    
  2. 注册监听器

    使用@Component注解标记TimeCountListener,Spring会自动将其注册为应用程序的事件监听器。


3. 优缺点分析

优点

  • 简单易用:无需对业务代码进行侵入式修改,只需创建监听器类。
  • 准确性高:Spring会在请求处理完成后发布事件,记录的时间较为准确。
  • 低侵入性:与业务逻辑代码解耦,易于维护和扩展。

缺点

  • 性能开销:尽管开销较小,但记录和处理事件仍然会增加系统的负担。
  • 事件丢失:在高并发或系统异常情况下,事件可能会丢失或记录不全。

4. 测试与验证

在这里插入图片描述

要测试TimeCountListener的有效性,可以创建一个测试接口,并在其上执行不同的请求。以下是一个简单的测试示例:

 package com.artisan.controller;import com.artisan.domain.Artisan;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.util.Arrays;/*** @author 小工匠* @version 1.0* @description: TODO* @date 2021/1/9 22:39* @mark: show me the code , change the world*/@RestController
public class ArtisanController {@RequestMapping("/hi")public String test() {return "小工匠 每日一博";}@RequestMapping("/hi2")public Object test2() {Artisan artisan = new Artisan();artisan.setName("小工匠");artisan.setAge(18);artisan.setHobbies(Arrays.asList("code", "sleep", "study"));return artisan;}/*** 处理GET请求,返回自定义的响应* 该方法通过@RequestParam接收id和kw作为查询参数,然后构建一个自定义的响应返回给调用者* 主要用于演示如何在Spring MVC中返回自定义的响应体和响应头** @param id 需要查询的ID* @return 自定义的响应对象,包含响应体、响应头和HTTP状态码*/@GetMapping("/hi3")public Object index(Long id) {// 创建HttpHeaders对象,用于自定义响应头HttpHeaders headers = new HttpHeaders();// 向响应头中添加自定义的版本信息headers.add("x-version", "v1");// 创建响应对象,设置响应体、响应头和HTTP状态码ResponseEntity<Object> response = new ResponseEntity<>(// 构建响应体内容,格式化输出id和kwString.format("id = %d", id),headers,HttpStatus.valueOf(200));// 返回自定义的响应对象return response;}}

访问 http://localhost:7777/hi3?id=1

在这里插入图片描述


小结

使用Spring的ServletRequestHandledEvent进行接口请求性能监控是一种简单且有效的方法。通过创建一个监听器,可以轻松地获取请求的详细性能信息,而无需对现有代码进行重大修改。然而,这种方法也有其局限性,如轻微的性能开销和潜在的事件丢失问题。


其他方案

1. 自定义拦截器

概述:自定义拦截器可以用来在请求处理的不同阶段(如请求前、请求后、请求完成后)添加额外的逻辑。

实现步骤

  • 实现HandlerInterceptor接口,覆盖其中的方法,如preHandlepostHandle、和afterCompletion
  • 在这些方法中记录请求开始时间、结束时间,计算处理时间。
  • 将拦截器注册到Spring MVC配置中。

示例代码

public class PerformanceInterceptor implements HandlerInterceptor {private static final Logger logger = LoggerFactory.getLogger(PerformanceInterceptor.class);@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {request.setAttribute("startTime", System.currentTimeMillis());return true;}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {long startTime = (Long) request.getAttribute("startTime");long endTime = System.currentTimeMillis();long executeTime = endTime - startTime;logger.info("请求URL: {},耗时: {} ms", request.getRequestURI(), executeTime);}
}

优点:能够灵活控制每个请求的处理过程,精确测量请求耗时。

2. 性能监控平台

概述:使用专用的性能监控平台可以提供丰富的可视化和分析功能,帮助识别性能瓶颈。

常用工具

  • Prometheus和Grafana:Prometheus用于数据收集和监控,Grafana用于数据可视化和告警设置。
  • New Relic:提供全面的应用性能监控,支持多种编程语言和框架。
  • AppDynamics:实时监控应用性能,帮助快速定位问题。

集成步骤

  • 在应用中集成相应的监控客户端库。
  • 配置监控指标和数据收集策略。
  • 在监控平台上设置仪表板,实时观察应用性能数据。

优点:提供全面的性能数据分析和可视化,支持告警和历史数据回溯。

3. 使用Spring Boot Actuator

概述:Spring Boot Actuator提供了一组生产级的监控功能,包括指标、健康检查、审计等。

集成步骤

  • 在Spring Boot项目中引入spring-boot-starter-actuator依赖。
  • 配置application.properties启用所需的监控端点。
  • 使用内置的HTTP端点或JMX监控应用的健康状况和性能指标。

示例配置

management.endpoints.web.exposure.include=*

优点:集成简单,提供丰富的监控端点,适合Spring Boot应用。

4. APM工具

概述:应用性能管理(APM)工具可以帮助全面监控和分析应用性能,识别瓶颈并优化性能。

常用工具

  • Elastic APM:与Elastic Stack整合,提供应用性能监控和日志管理。
  • Datadog:支持云原生应用监控,提供全面的性能数据。
  • Skywalking:支持云原生应用监控,提供全面的性能数据。

优点:提供详细的性能分析报告和可视化,易于识别和解决性能问题。

在这里插入图片描述

相关文章:

  • <数据集>停车场空位识别数据集<目标检测>
  • LabVIEW位移检测系统
  • 【CPP】slt-list由认识到简化模拟实现深度理解~
  • 储能集装箱动环监控系统,动环监控在集装箱的应用方案@卓振思众
  • 安科瑞Home EMS:引领家庭光储新纪元,让每一度电都尽在掌握
  • 旋转图像
  • Linux驱动开发—平台总线模型详解
  • 【多线程-从零开始-捌】阻塞队列,消费者生产者模型
  • Unity Android端截图保存并获取展示
  • Milvus向量数据库的简介以及用途
  • 怎么判断张量的维度(形状(shape)),即如何定义行数、列数和深度的?
  • ARM 架构硬件新趋势:嵌入式领域的未来
  • 【C#语音文字互转】.NET的TTS文本转语音合成
  • Java面试篇(线程池相关专题)
  • 问题解决:CUDA_HOME environment variable is not set.
  • 自己简单写的 事件订阅机制
  • Angularjs之国际化
  • bearychat的java client
  • Cumulo 的 ClojureScript 模块已经成型
  • docker-consul
  • dva中组件的懒加载
  • Electron入门介绍
  • iOS小技巧之UIImagePickerController实现头像选择
  • Java程序员幽默爆笑锦集
  • Java多态
  • Java教程_软件开发基础
  • OpenStack安装流程(juno版)- 添加网络服务(neutron)- controller节点
  • PHP变量
  • Python学习之路16-使用API
  • springboot_database项目介绍
  • 从0到1:PostCSS 插件开发最佳实践
  • 浮动相关
  • 规范化安全开发 KOA 手脚架
  • 计算机常识 - 收藏集 - 掘金
  • 买一台 iPhone X,还是创建一家未来的独角兽?
  • 前端js -- this指向总结。
  • 如何使用Mybatis第三方插件--PageHelper实现分页操作
  • 一加3T解锁OEM、刷入TWRP、第三方ROM以及ROOT
  • MiKTeX could not find the script engine ‘perl.exe‘ which is required to execute ‘latexmk‘.
  • postgresql行列转换函数
  • ​ssh免密码登录设置及问题总结
  • ​必胜客礼品卡回收多少钱,回收平台哪家好
  • ​学习一下,什么是预包装食品?​
  • ​中南建设2022年半年报“韧”字当头,经营性现金流持续为正​
  • # Redis 入门到精通(一)数据类型(4)
  • ### Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException
  • #我与Java虚拟机的故事#连载06:收获颇多的经典之作
  • (1)Nginx简介和安装教程
  • (2022 CVPR) Unbiased Teacher v2
  • (十)Flink Table API 和 SQL 基本概念
  • (十一)c52学习之旅-动态数码管
  • (数位dp) 算法竞赛入门到进阶 书本题集
  • (转载)虚函数剖析
  • .NET Core 中的路径问题
  • .net websocket 获取http登录的用户_如何解密浏览器的登录密码?获取浏览器内用户信息?...