SpringBoot通过注解监测Controller接口的代码示例

 更新时间:2024年07月29日 10:39:00   作者:奋斗的狍子007  
在Spring Boot中,度量指标(Metrics)是监控和诊断应用性能与行为的重要工具,Spring Boot通过集成Micrometer和Spring Boot Actuator,提供了强大的度量指标收集与暴露功能,本文介绍了SpringBoot通过注解监测Controller接口,需要的朋友可以参考下

一、前言

在Spring Boot中,度量指标(Metrics)是监控和诊断应用性能与行为的重要工具。Spring Boot通过集成Micrometer和Spring Boot Actuator,提供了强大的度量指标收集与暴露功能。

二、度量指标

1. Micrometer

Micrometer是一个应用监控门面(Facade),它提供了对多种监控系统的支持,使得开发者可以在不修改代码的情况下切换监控后端,如Prometheus、Graphite、InfluxDB等。

Micrometer的核心功能

丰富的指标收集

系统指标:如CPU使用率、内存占用、磁盘I/O、网络I/O等,这些基础资源的使用情况对于理解系统性能至关重要。

应用指标:包括请求响应时间、吞吐量、错误率等,这些指标直接反映了应用的行为和性能。

自定义指标:开发者可以根据需要创建自定义指标,以监控特定的业务流程或组件。

请求跟踪:

虽然Micrometer本身主要关注于指标收集,但它可以与Spring Cloud Sleuth等跟踪系统结合使用,实现请求的分布式跟踪。Sleuth通过添加跟踪信息(如Trace ID、Span ID)到日志和指标中,帮助开发者追踪请求在整个微服务架构中的路径,从而更容易地诊断问题。

集成日志记录:

虽然Micrometer不直接处理日志记录,但将Micrometer的监控数据与日志系统集成,可以形成更全面的可观测性体系。例如,可以将Micrometer收集的指标与日志文件中的Trace ID关联起来,从而更容易地将性能问题与具体的请求或事务联系起来。

2. Spring Boot Actuator

Spring Boot Actuator是Spring Boot的一个子项目,它提供了对应用系统的自省和监控的集成功能。通过引入Spring Boot Actuator,应用可以暴露多个端点(Endpoints),这些端点提供了对应用内部信息的访问,包括度量指标、健康检查、环境变量等。

三、使用@Timed, @Counted注解来完成接口的监测功能

@Timed注解

该注解会统计方法调用的执行耗时情况,包括什么类,哪个方法等信息。

@Counted注解

统计方法调用成功与失败情况。

四、代码示例

1. 引入依赖

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

<dependency>
	<groupId>io.micrometer</groupId>
	<artifactId>micrometer-registry-prometheus</artifactId>
</dependency>

2. 开启配置

management.endpoints.web.base-path=/v/ac
management.endpoints.web.exposure.include=*

3. 测试代码

@Timed(value = "test_actuator", description = "test_actuator", histogram = true)
@RequestMapping("/test/actuator")
public void testActuator(String name){
	// 相关业务
	System.out.println("success: " + name);
}

http_server_requests_seconds_count:调用次数

http_server_requests_seconds_sum:总计耗时(总次数时间合计)。

http_server_requests_seconds_max:最大耗时时长

以上就是SpringBoot通过注解监测Controller接口的代码示例的详细内容,更多关于SpringBoot注解监测Controller的资料请关注脚本之家其它相关文章!

相关文章

  • java实现窗口刷新的示例代码

    java实现窗口刷新的示例代码

    本文主要介绍了java实现窗口刷新的示例代码,通过重写paintComponent()方法和调用repaint()方法,可以实现窗口的即时刷新,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • SpringBoot+Maven 多模块项目的构建、运行、打包实战

    SpringBoot+Maven 多模块项目的构建、运行、打包实战

    这篇文章主要介绍了SpringBoot+Maven 多模块项目的构建、运行、打包实战,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • java实现的日期时间转换工具类完整示例

    java实现的日期时间转换工具类完整示例

    这篇文章主要介绍了java实现的日期时间转换工具类,结合完整实例形式分析了java针对日期时间常见的转换、计算、格式化等相关操作与封装技巧,需要的朋友可以参考下
    2019-10-10
  • 详解Java正则表达式语法

    详解Java正则表达式语法

    这篇文章主要介绍了Java正则表达式语法,包括常用正则表达式、匹配验证-验证Email是否正确以及字符串中查询字符或者字符串,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • 详解在Spring Boot框架下使用WebSocket实现消息推送

    详解在Spring Boot框架下使用WebSocket实现消息推送

    这篇文章主要介绍了详解在Spring Boot框架下使用WebSocket实现消息推送,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2016-12-12
  • 一篇看懂Java中的Unsafe类

    一篇看懂Java中的Unsafe类

    在阅读AtomicInteger的源码时,看到了这个类:sum.msic.Unsafe,之前从没见过。所以花了点时间研究了下,下面这篇文章主要给大家介绍了关于Java中Unsafe类的相关资料,需要的朋友可以参考借鉴,下面来一起学习学习吧
    2018-05-05
  • java关键字final使用方法详解

    java关键字final使用方法详解

    在程序设计中,我们有时可能希望某些数据是不能够改变的,这个时候final就有用武之地了。final是java的关键字,本文就详细说明一下他的使用方法
    2013-11-11
  • springboot的@Value中#和$区别详解

    springboot的@Value中#和$区别详解

    这篇文章主要介绍了springboot的@Value中#和$区别详解,@Value注解的作用主要可以给属性直接赋值、也可以读取配置文件中的值给属性赋值,需要的朋友可以参考下
    2023-11-11
  • SpringBoot+Vue+Redis实现单点登录(一处登录另一处退出登录)

    SpringBoot+Vue+Redis实现单点登录(一处登录另一处退出登录)

    小编接到一个需求,需要实现用户在浏览器登录后,跳转到其他页面,当用户在其它地方又登录时,前面用户登录的页面退出登录,这篇文章主要介绍了SpringBoot+Vue+Redis实现单点登录,需要的朋友可以参考下
    2019-12-12
  • struts2的国际化实现网站整体中英文切换实例代码

    struts2的国际化实现网站整体中英文切换实例代码

    本篇文章主要介绍了struts2的国际化实现网站整体中英文切换实例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-10-10

最新评论