Spring Boot 中的监视器是什么?有什么作用?

前言:

监听器相信熟悉 Spring、Spring Boot 的都知道,但是监视器又是什么?估计很多人一脸懵的状态,本篇分享一下 Spring Boot 的监视器。

Spring Boot 系列文章传送门

Spring Boot 启动流程源码分析(2)

Spring Boot 启动流程源码分析(2)

Spring Boot 自动配置实现原理(源码分析)

Spring Boot 自定义 starter 启动器

Spring Boot 事件监听机制工作原理

Spring Boot 事件监听机制实战【自定义 Spring Boot 事件监听】

Spring Boot 的监视器是什么?

Spring Boot 的监视器一种特殊的应用程序或组件,用于监控和管理整个应用程序的运行状态和性能,它提供了一种可视化的方式,可以实时跟踪和监视应用程序的各种指标,例如响应时间、CPU使用率、内存使用情况等,Spring Boot 提供了一些内置的监视器功能,可以集成到应用程序中,Spring Boot 监视器功能由各种监视器监视器 Bean 实现,比如 Spring Boot Actuator。

什么是 Spring Boot Actuator?

Spring Boot Actuator 是一个用于监控和管理 Spring Boot 应用程序的模块,它提供了许多端点,可以通过 HTTP 请求来访问这些端点,来获取应用程序的各种信息,如健康状况、度量指标、配置信息等,Actuator还可以通过配置开启或关闭特定的端点,并提供自定义的端点。

Spring Boot Actuator 可以做什么?

  1. 指标监控:实时跟踪应用程序的各种指标,例如响应时间、CPU使用率、内存使用情况等,以便进行性能优化和故障排查。
  2. 健康检查:检查应用程序的健康状况,包括是否正常运行(非常实用)。
  3. 日志管理:记录应用程序的日志信息,包括错误日志、警告日志、调试日志等,以便进行性能优化和故障排查。。
  4. 端点监控:监控应用程序中的各种端点(HTTP接口),包括请求数量、请求时间、响应时间等。

Spring Boot Actuator 使用演示

在 pom.xml 中引入 management.endpoints.web.exposure.include=*

组件,如下:

xml 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

在程序的配置文件中启用 Actuator

yaml 复制代码
#暴露所有的端点
management.endpoints.web.exposure.include=*
  • 号的配置是允许所有的 Actuator 端点通过 HTTP 请求访问,生产环境不建议这样配置。

启动应用程序获取程序的健康情况:http://localhost:port/actuator/health

结果如下:

符合预期,我们的程序是健康的。

自定义 Endpoint

注解说明

  • @Endpoint:可通过JMX和web应用程序访问。
  • @JmxEndpoint:只能通过 JMX 访问。
  • @WebEndpoint:只能通过 WEB 应用访问。
  • @ReadOperation:相当于 GET 请求。
  • @WriteOperation:相当于 POST 请求。
  • @DeleteOperation:相当于 DELETE 请求。

有时候我们需要自定义自己的端点,我们可以通过 @Endpoint注解 + @ReadOperation、@WriteOperation、@DeleteOperation 注解来实现自定义端点,代码如下:

java 复制代码
@Component
@Endpoint(id = "myActuatorEndpoint")
public class MyActuatorController {

    @ReadOperation
    public Map<String, Object> get() {
        Map<String, Object> map = new HashMap<>();
        map.put("httpMethod", HttpMethod.GET.toString());
        return map;
    }

    @WriteOperation
    public Map<String, Object> post() {
        Map<String, Object> map = new HashMap<>();
        map.put("httpMethod", HttpMethod.POST.toString());
        return map;
    }

    @DeleteOperation
    public Map<String, Object> delete() {
        Map<String, Object> map = new HashMap<>();
        map.put("httpMethod", HttpMethod.DELETE.toString());
        return map;
    }
}

GET 方式测试结果:

结果符合预期,另外两种方式这里不做测试了,有兴趣的可以自己去测试一下。

自定义端口

我们还可以自定义监控的端口

yaml 复制代码
#自定义端口
management.server.port=8082

如有不正确的地方请各位指出纠正。

相关推荐
MiniFlyZt3 分钟前
消息队列MQ(RabbitMQ)
spring boot·分布式·微服务·rabbitmq
大丈夫在世当日食一鲲4 分钟前
Java中用到的设计模式
java·开发语言·设计模式
A-Kamen8 分钟前
Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实战指南
java·spring boot·后端
练川10 分钟前
Stream特性(踩坑):惰性执行、不修改原始数据源
java·stream
豆豆酱13 分钟前
Transformer结构详解
后端
upsilon14 分钟前
golang切片slice
后端·go
狂奔小菜鸡14 分钟前
Java运行时数据区
java·jvm·后端
lovebugs15 分钟前
Java并发编程之Lock机制:更灵活的线程同步方案
后端·面试
kunge201316 分钟前
Paddle快速入门
后端
trymoLiu21 分钟前
SpringBoot 实现 RSA+AES 自动接口解密!
java·spring boot