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

Spring Boot Actuator 保姆级教程

1. 引言

Spring Boot Actuator 是一个功能强大的监控工具,能够帮助开发者监控和管理应用的运行状态。通过 Actuator,我们可以轻松获取应用的健康状况、配置信息、性能指标等。本文将一步步引导你如何配置和使用 Actuator,以及如何通过它来监控你的 Spring Boot 应用。

2. 安装和配置 Actuator

2.1 添加依赖

首先,我们需要在项目的 pom.xml 文件中添加 Actuator 的依赖:

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

2.2 启用 Actuator 端点

默认情况下,Actuator 的一些敏感端点是禁用的。我们需要在配置文件中启用它们。在 application.propertiesapplication.yml 中添加以下配置:

management:endpoints:web:exposure:include: "*"

这样,所有的 Actuator 端点都会被启用。你也可以选择性地启用部分端点,例如:

management:endpoints:web:exposure:include: health, info, metrics

2.3 访问 Actuator 端点

配置完成后,启动你的 Spring Boot 应用。默认情况下,Actuator 端点的访问路径是 /actuator。你可以通过浏览器或工具(如 Postman)访问以下路径:

  • http://localhost:8080/actuator:列出所有可用的端点。
  • http://localhost:8080/actuator/health:检查应用的健康状态。
  • http://localhost:8080/actuator/info:查看应用的配置信息。

3. 探索常用 Actuator 端点

3.1 Health 端点

/actuator/health 端点用于检查应用的健康状态。默认情况下,它返回一个简单的状态,例如:

{"status": "UP"
}

为了查看更详细的健康信息,可以在配置文件中添加:

management:endpoint:health:show-details: always

重启应用后,再次访问 /actuator/health,你将看到更详细的健康指标,包括磁盘空间、数据库连接等。

3.2 Info 端点

/actuator/info 端点显示应用的配置信息。你可以在 application.yml 中添加自定义的信息:

info:app:name: MySpringBootApplicationversion: 1.0.0

访问 /actuator/info 将返回这些配置信息:

{"app": {"name": "MySpringBootApplication","version": "1.0.0"}
}

3.3 Beans 端点

/actuator/beans 端点展示了应用中所有 Spring Bean 的信息,包括它们的类型、作用域和依赖关系。这对于调试和理解应用的依赖关系非常有帮助。

3.4 Metrics 端点

/actuator/metrics 端点提供了应用的性能指标,包括 JVM 内存使用情况、线程信息、HTTP 请求统计等。你可以通过这个端点监控应用的实时性能。

3.5 Threaddump 端点

/actuator/threaddump 端点生成当前线程的快照,帮助你分析线程的状态和堆栈信息。这对于排查线程相关的问题非常有用。

3.6 Shutdown 端点

/actuator/shutdown 端点允许你通过发送一个 POST 请求来优雅地关闭应用。在配置文件中启用它:

management:endpoint:shutdown:enabled: true

然后,使用工具发送 POST 请求到 http://localhost:8080/actuator/shutdown 即可关闭应用。

4. 自定义 Actuator 端点

4.1 创建自定义 Endpoint

有时候,你可能需要监控一些特定的业务逻辑。这时,可以创建自定义的 Actuator 端点。例如,创建一个名为 myEndpoint 的端点:

import org.springframework.boot.actuate.endpoint.annotation.Endpoint;
import org.springframework.boot.actuate.endpoint.annotation.ReadOperation;
import org.springframework.stereotype.Component;@Component
@Endpoint(id = "myEndpoint")
public class MyEndpoint {@ReadOperationpublic String getInfo() {return "Custom endpoint information";}
}

4.2 注册 Endpoint

确保你的自定义 Endpoint 被 Spring 容器注册。通常,使用 @Component 注解即可。

4.3 访问自定义端点

启动应用后,访问 http://localhost:8080/actuator/myEndpoint,你将看到自定义的信息。

5. 保护 Actuator 端点

5.1 使用 Filter 保护端点

为了防止未经授权的访问,可以为 Actuator 端点添加过滤器。例如,创建一个过滤器类:

import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;@WebFilter(urlPatterns = "/actuator/*")
@Component
public class ActuatorFilter implements Filter {@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {HttpServletRequest httpRequest = (HttpServletRequest) request;HttpServletResponse httpResponse = (HttpServletResponse) response;// 检查用户是否认证if (!isAuthenticated(httpRequest)) {httpResponse.setStatus(HttpServletResponse.SC_UNAUTHORIZED);httpResponse.getWriter().write("Unauthorized access");return;}chain.doFilter(request, response);}private boolean isAuthenticated(HttpServletRequest request) {// 实现认证逻辑,例如检查是否有有效的令牌return request.getHeader("Authorization") != null;}
}

5.2 配置过滤器

确保过滤器类被 Spring 容器扫描到。通常,将其放在 src/main/java 目录下的适当包中即可。

6. 使用 Spring Boot Monitor 可视化监控

6.1 引入依赖

pom.xml 中添加 Spring Boot Monitor 的依赖:

<dependency><groupId>cn.pomit</groupId><artifactId>spring-boot-monitor</artifactId><version>0.0.1</version>
</dependency>

6.2 访问监控页面

启动应用后,访问 http://localhost:8080/monitor,你将看到一个类似 Spring Boot Admin 的监控界面,展示应用的各项指标和健康状态。

7. 总结

通过本文的教程,你已经掌握了如何配置和使用 Spring Boot Actuator 来监控和管理你的应用。从启用默认端点到创建自定义端点,再到保护端点的安全性,Actuator 提供了丰富的功能来满足不同的监控需求。希望这篇教程能帮助你更好地理解和应用 Actuator,提升应用的监控和管理能力。

http://www.lryc.cn/news/607397.html

相关文章:

  • JavaWeb--Student2025项目:增删改查
  • 七彩喜艾灸机器人:让传统艾灸变简单,健康养生触手可及
  • HarmonyOS 应用拉起系列(一):应用与元服务互通方式
  • 乐观锁是数据库和多线程编程中常用的一种控制并发的方法
  • 【数据可视化-77】中国历年GDP数据可视化分析:Python + Pyecharts 深度洞察(含完整数据、代码)
  • 伞状Meta分析重构癌症幸存者照护指南:从矛盾证据到精准决策
  • OSPF综合实验报告册
  • 从游戏NPC到手术助手:Agent AI重构多模态交互,具身智能打开AGI新大门
  • 基于倍增的LCA + kruskal重构树 + 并查集
  • 第三章 网络安全基础(一)
  • 【Redis】key的设计格式
  • dolphinscheduler中一个脚本用于从列定义中提取列名列表
  • 香港正式启动稳定币牌照制度!推动中国的人民币国际化?
  • SQL中的LEFT JOIN
  • 微服务的编程测评系统9-竞赛新增-竞赛编辑
  • Flask一个用户同时只能在一处登录实现
  • Linux网络:多路转接 epoll
  • CentOS7下同步时间的几种方式(NTP 、Chrony和systemd-timesyncd)
  • iPhone 恢复出厂设置是否会删除所有内容?
  • iPhone查看App日志和系统崩溃日志的完整实用指南
  • 用落霞归雁的思维框架推导少林寺用什么数据库?
  • Syzkaller实战教程6:[重要]初始种子加载机制剖析第二集
  • 使用 Docker 部署 Label Studio 时本地文件无法显示的排查与解决
  • 无人机自动跟随模块技术分析
  • Docker 实战 -- Nextcloud
  • 【05】VM二次开发——模块参数配置--带渲染/不带渲染(WinForm界面调用 模块参数配置)
  • Java 日期时间处理:分类、用途与性能分析
  • 前端学习日记(十七)
  • Ant 构建java项目
  • FastDDS (SharedMemory)