SpringBootActuator监控配置详解
Spring Boot Actuator是Spring Boot应用强大的监控利器,通过配置可洞察应用健康状况、性能指标等关键信息。本文深入解析Actuator的安全配置与扩展实践,强调权限控制、网络隔离、HTTPS加密以及端点限制的重要性,避免敏感信息泄露。同时,探讨如何自定义HealthIndicator扩展健康检查逻辑,并利用health groups实现更细粒度的健康监测。通过本文,你将掌握Actuator的配置技巧,为你的Spring Boot应用打造安全可靠的监控体系,提升运维效率,快速定位并解决潜在问题。
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学习网公众号!

- 上一篇
- 正则表达式回溯是什么?如何避免?

- 下一篇
- Win10激活码能买吗?如何安全购买正版激活码
-
- 文章 · java教程 | 1分钟前 |
- HTTP/3协议在Java中的实现详解
- 164浏览 收藏
-
- 文章 · java教程 | 7分钟前 |
- Java单例模式详解与实现技巧
- 197浏览 收藏
-
- 文章 · java教程 | 16分钟前 |
- Java开发工业相机SDK操作全解析
- 398浏览 收藏
-
- 文章 · java教程 | 19分钟前 |
- JavaSpotBugs防空指针,提升代码可靠性
- 176浏览 收藏
-
- 文章 · java教程 | 25分钟前 |
- Java并发框架WorkStealingPool原理解析
- 202浏览 收藏
-
- 文章 · java教程 | 25分钟前 |
- 编译检查差异:Checked与Unchecked异常解析
- 201浏览 收藏
-
- 文章 · java教程 | 32分钟前 |
- JavaMap使用技巧与键值对操作
- 256浏览 收藏
-
- 文章 · java教程 | 38分钟前 |
- Java消息队列幂等处理技巧分享
- 376浏览 收藏
-
- 文章 · java教程 | 43分钟前 |
- SpringCloud微服务注册中心搭建指南
- 130浏览 收藏
-
- 文章 · java教程 | 1小时前 | 动态路由 filter predicate 路由配置 SpringCloudGateway
- SpringCloudGateway路由配置详解
- 343浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Error和Exception的区别:哪些错误无法捕获?
- 226浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 509次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 边界AI平台
- 探索AI边界平台,领先的智能AI对话、写作与画图生成工具。高效便捷,满足多样化需求。立即体验!
- 214次使用
-
- 免费AI认证证书
- 科大讯飞AI大学堂推出免费大模型工程师认证,助力您掌握AI技能,提升职场竞争力。体系化学习,实战项目,权威认证,助您成为企业级大模型应用人才。
- 240次使用
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 357次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 441次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 378次使用
-
- 提升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浏览