SpringBootActuator监控配置详解
本文深入解析了Spring Boot Actuator的监控配置,旨在帮助开发者安全有效地利用Actuator监控应用状态。首先强调了安全配置的重要性,包括通过Spring Security进行权限控制,限制特定角色或IP访问敏感端点;建议将Actuator部署在内网或通过堡垒机访问,启用HTTPS加密通信,并按需暴露必要端点。此外,还探讨了如何自定义HealthIndicator扩展健康检查逻辑,并利用health groups划分核心与非核心服务状态,实现更细粒度的健康监测。通过合理的配置,Actuator能成为日常运维和故障排查的得力助手,提升应用的可观测性和安全性。
Spring Boot Actuator的监控接口需通过权限控制、网络隔离、HTTPS加密及限制暴露端点等方式安全配置。首先,结合Spring Security配置拦截规则,仅允许特定角色或IP访问敏感端点;其次,将Actuator部署在内部网络或通过堡垒机访问,避免公网暴露;第三,启用HTTPS确保通信安全;第四,按需暴露必要端点,而非无差别开放全部接口。此外,可自定义HealthIndicator扩展健康检查逻辑,并利用health groups划分核心与非核心服务状态,实现更细粒度的健康监测。
Spring Boot Actuator,在我看来,它就是Spring Boot应用的一双“眼睛”和“耳朵”,甚至还有些“手脚”。它能让你在不深入代码的情况下,洞察应用内部的健康状况、性能指标、环境变量,甚至还能动态调整日志级别。配置得当,它能成为你日常运维和故障排查的得力助手,避免很多抓瞎的情况。当然,配置这东西,不是一股脑儿全开,得有策略,有取舍。

关于Actuator的配置,这块儿其实挺灵活的,但也容易让人迷糊。最基础的,你得先在 pom.xml
里把依赖加上:

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>
加了依赖,Actuator的默认端点(比如 /health
, /info
)就有了,但默认情况下,大部分端点是不会通过HTTP暴露的,除了 /health
和 /info
。如果你想看到更多,比如 /metrics
、/loggers
,就需要显式地暴露它们。这通常在 application.properties
或 application.yml
里搞定:
# application.yml 示例 management: endpoints: web: exposure: include: "*" # 暴露所有端点,生产环境慎用! # 或者指定需要暴露的端点,比如: # include: health,info,metrics,loggers base-path: /manage # 可以自定义Actuator端点的基础路径,默认是 /actuator server: port: 8081 # 可以将Actuator接口独立部署在另一个端口,与业务端口分离,提高安全性
我个人习惯是,如果条件允许,会把Actuator放到一个独立的管理端口上,比如 8081
,这样业务流量和管理流量就分开了,感觉更清晰,也方便做网络隔离。

每个端点都有自己的配置,比如 health
端点,你可以控制它是否显示详细信息:
management.endpoint.health.show-details: always
或者 never
,或者 when-authorized
。这个细节展示,调试的时候挺有用,但生产环境直接暴露给所有人就不太合适了。
再比如 shutdown
端点,默认是禁用的,因为这玩意儿太危险了,一不小心就把应用关了。如果你真的需要远程关闭,得手动启用:
management.endpoint.shutdown.enabled: true
然后还得配合安全措施,不然就是个大坑。
如何安全地暴露Spring Boot Actuator监控接口,避免潜在风险?
这个问题,是Actuator配置里最值得花时间琢磨的。你把应用内部的“秘密”暴露出来,就得考虑谁能看、怎么看。我见过不少项目,直接 include: "*"
然后裸奔在公网,这简直是给攻击者敞开大门。
最常见的做法,也是我强烈推荐的:结合Spring Security进行权限控制。 你可以配置拦截规则,只允许特定角色或IP地址访问Actuator端点。 一个简单的例子,如果你已经集成了Spring Security:
// 在你的SecurityConfig类中 @Configuration @EnableWebSecurity public class SecurityConfig { @Bean public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { http .authorizeHttpRequests(authz -> authz // 允许健康检查和信息端点无需认证访问(如果需要) .requestMatchers("/manage/health", "/manage/info").permitAll() // 其他Actuator端点需要ADMIN角色 .requestMatchers("/manage/**").hasRole("ADMIN") // 其他所有请求需要认证 .anyRequest().authenticated() ) .httpBasic(withDefaults()) // 或者formLogin .csrf(csrf -> csrf.disable()); // 生产环境慎重禁用CSRF return http.build(); } }
这里我用了 /manage
作为Actuator的基础路径,这是前面 management.endpoints.web.base-path
配置的体现。这样一来,只有拥有 ADMIN
角色的用户才能访问 /manage/metrics
这样的敏感接口。
除了权限控制,还有一些辅助手段:
- 网络隔离: 最佳实践是将Actuator接口部署在内部网络,或者通过堡垒机访问,不直接暴露到公网。
- HTTPS: 确保所有通信都加密,防止数据被窃听。
- 限制暴露的端点: 永远不要在生产环境无脑
include: "*"
。只暴露你真正需要的,比如health
,info
,metrics
。像env
,beans
,mappings
这样的,除非有特殊需求且安全措施到位,否则最好别露。
Spring Boot Actuator的健康检查(/health)如何进行深度定制和扩展?
默认的 /health
端点,它会检查数据库连接、磁盘空间、Redis连接等等,这些都是Spring Boot自动集成的。但很多时候,这还不够。比如你的应用依赖一个外部的微服务,或者需要确保某个队列服务是可用的,这些默认的健康检查是感知不到的。
这时候,你就需要自定义 HealthIndicator
了。这其实很简单,实现 org.springframework.boot.actuate.health.HealthIndicator
接口就行:
import org.springframework.boot.actuate.health.Health; import org.springframework.boot.actuate.health.HealthIndicator; import org.springframework.stereotype.Component; @Component public class MyServiceHealthIndicator implements HealthIndicator { // 假设这是你依赖的某个外部服务 private final ExternalService externalService; public MyServiceHealthIndicator(ExternalService externalService) { this.externalService = externalService; } @Override public Health health() { try { // 尝试调用外部服务的一个简单接口,检查是否可用 if (externalService.isReachable()) { return Health.up().withDetail("message", "External service is reachable.").build(); } else { return Health.down().withDetail("error", "External service is unreachable.").build(); } } catch (Exception e) { // 捕获异常,表示服务不可用 return Health.down(e).withDetail("message", "Failed to check external service.").build(); } } }
这样,当你访问 /health
时,除了默认的检查项,还会多一个 myService
的状态。
另外,你还可以利用 health groups
来组织健康检查。比如,你可能有一组核心服务必须是健康的,另一组非核心服务即使挂了也不影响主流程。
management: endpoint: health: show-details: always groups: readiness: # 准备就绪探针,用于判断应用是否可以接收流量 include: db,redis,myService # 包含核心组件 liveness: # 存活探针,用于判断应用是否还活着 include: diskSpace,ping # 只包含最基本的检查
这样,你就可以通过 /health/readiness
和 /health/liveness
访问不同维度的健康状态,这对于Kubernetes等容器编排平台上的健康探针配置非常有用。我经常用这个来区分“我还能不能活”和“我准备好干活了吗”这两种状态。
深入理解Spring Boot Actuator的度量(/metrics)功能及其扩展实践
/metrics
端点,这绝对是Actuator的另一大亮点。它基于Micrometer,提供了一套非常强大的应用度量体系。你可以通过它看到JVM内存使用、CPU负载、HTTP请求处理时间、数据库连接池活跃数等等,这些数据
本篇关于《SpringBootActuator监控配置详解》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

- 上一篇
- 即梦AI语音转文字教程与字幕制作方法

- 下一篇
- Linux入门第12天学习笔记整理
-
- 文章 · java教程 | 2分钟前 |
- Java对象实例化是什么,如何正确创建对象
- 440浏览 收藏
-
- 文章 · java教程 | 12分钟前 |
- Java实现HTTP长连接保持方法
- 291浏览 收藏
-
- 文章 · java教程 | 20分钟前 |
- Java泛型编译检查机制解析
- 131浏览 收藏
-
- 文章 · java教程 | 22分钟前 |
- JavaStreamAPI过滤映射排序全解析
- 360浏览 收藏
-
- 文章 · java教程 | 47分钟前 |
- JavaCallable与Future用法详解
- 499浏览 收藏
-
- 文章 · java教程 | 58分钟前 | 密钥管理 加密解密 敏感信息 SpringBoot配置中心 Jasypt
- SpringBoot加密配置中心实现指南
- 352浏览 收藏
-
- 文章 · java教程 | 1小时前 | java 天文数据
- Java读取FITS文件的实用方法
- 425浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- SpringCloudGateway灰度配置全解析
- 116浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java线程池优势与使用详解
- 312浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 509次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 边界AI平台
- 探索AI边界平台,领先的智能AI对话、写作与画图生成工具。高效便捷,满足多样化需求。立即体验!
- 295次使用
-
- 免费AI认证证书
- 科大讯飞AI大学堂推出免费大模型工程师认证,助力您掌握AI技能,提升职场竞争力。体系化学习,实战项目,权威认证,助您成为企业级大模型应用人才。
- 314次使用
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 437次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 536次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 446次使用
-
- 提升Java功能开发效率的有力工具:微服务架构
- 2023-10-06 501浏览
-
- 掌握Java海康SDK二次开发的必备技巧
- 2023-10-01 501浏览
-
- 如何使用java实现桶排序算法
- 2023-10-03 501浏览
-
- Java开发实战经验:如何优化开发逻辑
- 2023-10-31 501浏览
-
- 如何使用Java中的Math.max()方法比较两个数的大小?
- 2023-11-18 501浏览