package com.crhms.medicareopinion;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class HealthzController {
@GetMapping("/healthz")
public String healthz(){
return "OK";
} //可以添加自己的逻辑
访问如下:
这个做起来,也没什么问题,但是,当微服务多的时候,如果每个微服务都这样添加的时候,再这么做,我们就得想办法了,是否可以去重呢,抽象出检测的接口呢。
再有,如果我想在检查中统一加对数据库的检测,对缓存的检测,想想肯定又一堆代码了。
这时我发现了springboot Actuator。有了它,再实现类似的功能,就相当简单了。
只需要在pom.xml文件中,添加GAV即可:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
启动项目,访问http://localhost:8001/actuator/health
Actuator 提供了 13 个接口 也叫endpoint,具体如下表所示:
HTTP 方法路径描述
/autoconfig
提供了一份自动配置报告,记录哪些自动配置条件通过了,哪些没通过
/configprops
描述配置属性(包含默认值)如何注入Bean
/beans
描述应用程序上下文里全部的Bean,以及它们的关系
/dump
获取线程活动的快照
获取全部环境属性
/env/{name}
根据名称获取特定的环境属性值
/health
报告应用程序的健康指标,这些值由HealthIndicator的实现类提供
/info
获取应用程序的定制信息,这些信息由info打头的属性提供
/mappings
描述全部的URI路径,以及它们和控制器(包含Actuator端点)的映射关系
/metrics
报告各种应用程序度量信息,比如内存用量和HTTP请求计数
/metrics/{name}
报告指定名称的应用程序度量值
/shutdown
关闭应用程序,要求endpoints.shutdown.enabled设置为true
/trace
提供基本的HTTP请求跟踪信息(时间戳、HTTP头等)
默认接口只提供了health, info接口,如果想访问其他接口需添加配置:
management:
endpoints:
exposure:
include: "*"
health
只展示了简单的UP
和DOWN
状态。为了获得健康检查中所有指标的详细信息,你可以通过在application.yaml
中增加如下内容:
management:
endpoints:
exposure:
include: "*"
endpoint:
health:
show-details: always
如果你的程序配置了数据库的访问,那个还会把数据库的状态显示出来: