使用Spring Boot Actuator查看应用健康情况

Spring Boot Actuator 提供了强大的监控和管理功能,其中健康检查(Health)是最常用的功能之一。通过相关配置,可以全面监控 Spring Boot 应用的健康状况,并根据需要进行自定义扩展。

1. 添加依赖

首先在 pom.xml 中添加 Actuator 依赖:

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

或者在 build.gradle 中:

bash 复制代码
implementation 'org.springframework.boot:spring-boot-starter-actuator'

2. 基本配置

application.ymlapplication.properties 中进行基本配置:

application.yml

bash 复制代码
management:
  endpoints:
    web:
      exposure:
        include: health,info,metrics  # 暴露需要的端点
  endpoint:
    health:
      show-details: always  # 显示详细健康信息

application.properties

bash 复制代码
management.endpoints.web.exposure.include=health,info,metrics
management.endpoint.health.show-details=always

3. 访问健康端点

启动应用后,可以通过以下 URL 访问健康信息:

  • 基础健康信息 : http://localhost:8080/actuator/health
  • 详细健康信息 : http://localhost:8080/actuator/health(当配置了 show-details: always 时)

响应示例

简单响应

bash 复制代码
{
  "status": "UP"
}

详细响应

bash 复制代码
{
  "status": "UP",
  "components": {
    "diskSpace": {
      "status": "UP",
      "details": {
        "total": 500068036608,
        "free": 239096578048,
        "threshold": 10485760,
        "exists": true
      }
    },
    "ping": {
      "status": "UP"
    },
    "db": {
      "status": "UP",
      "details": {
        "database": "MySQL",
        "validationQuery": "isValid()"
      }
    }
  }
}

健康状态级别

Spring Boot 定义了以下健康状态:

  • UP: 组件正常运行
  • DOWN: 组件不可用
  • OUT_OF_SERVICE: 组件暂时不可用
  • UNKNOWN: 状态未知

整体应用状态由最差的组件状态决定。

常用健康检查端点

端点 说明
/actuator/health 应用健康状况
/actuator/info 应用基本信息
/actuator/metrics 应用指标
/actuator/env 环境变量
/actuator/loggers 日志配置
/actuator/beans 查看应用的beans

4. 自定义健康指示器

创建自定义的健康检查逻辑:

java 复制代码
@Component
public class CustomHealthIndicator implements HealthIndicator {
    
    @Override
    public Health health() {
        // 执行自定义健康检查逻辑
        boolean isHealthy = checkCustomService();
        
        if (isHealthy) {
            return Health.up()
                .withDetail("customService", "Available")
                .withDetail("version", "1.0.0")
                .build();
        } else {
            return Health.down()
                .withDetail("customService", "Unavailable")
                .withDetail("error", "Connection timeout")
                .build();
        }
    }
    
    private boolean checkCustomService() {
        // 实现具体的健康检查逻辑
        return true;
    }
}

5. 常见内置健康指示器

  • DiskSpaceHealthIndicator: 检查磁盘空间
  • DataSourceHealthIndicator: 检查数据库连接
  • RedisHealthIndicator: 检查 Redis 连接
  • RabbitHealthIndicator: 检查 RabbitMQ 连接
  • MongoHealthIndicator: 检查 MongoDB 连接

6. 高级配置选项

配置健康端点路径

bash 复制代码
# 修改基础路径
management.endpoints.web.base-path=/monitor  

# 自定义健康端点路径
management.endpoint.health.path=/health-check

权限控制

bash 复制代码
# 仅在认证后显示详细信息
management.endpoint.health.show-details=when_authorized

分组健康检查

bash 复制代码
management.endpoint.health.group.custom.include=db,diskSpace
management.endpoint.health.group.custom.show-details=always

访问分组健康检查:http://localhost:8080/actuator/health/custom

7. 生产环境最佳实践

bash 复制代码
# 生产环境配置示例

# 仅暴露必要的端点
management.endpoints.web.exposure.include=health,info

# 仅授权用户可见详细信息
management.endpoint.health.show-details=when_authorized

# 启用 Kubernetes 探针支持
management.endpoint.health.probes.enabled=true

# 禁用环境信息暴露
management.info.env.enabled=false

8. Kubernetes 探针集成

Actuator 还提供了专门的探针端点:

  • Liveness Probe : http://localhost:8080/actuator/health/liveness
  • Readiness Probe : http://localhost:8080/actuator/health/readiness

配置示例:

bash 复制代码
# 启用 Kubernetes 探针支持
management.endpoint.health.probes.enabled=true

# 仅授权用户可见详细信息
management.endpoint.health.show-details=when_authorized
相关推荐
JH30735 小时前
为什么switch不支持long
java
盐真卿6 小时前
python第八部分:高级特性(二)
java·开发语言
上海合宙LuatOS6 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
汤姆yu6 小时前
基于springboot的尿毒症健康管理系统
java·spring boot·后端
TT哇6 小时前
【实习】银行经理端线下领取扫码功能实现方案
java
暮色妖娆丶6 小时前
Spring 源码分析 单例 Bean 的创建过程
spring boot·后端·spring
野犬寒鸦6 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习
黎雁·泠崖6 小时前
【魔法森林冒险】2/14 抽象层设计:Figure/Person类(所有角色的基石)
java·开发语言
怒放吧德德7 小时前
后端 Mock 实战:Spring Boot 3 实现入站 & 出站接口模拟
java·后端·设计
biyezuopinvip7 小时前
基于Spring Boot的企业网盘的设计与实现(任务书)
java·spring boot·后端·vue·ssm·任务书·企业网盘的设计与实现