引入依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
相关yml的配置:
#management是所有actuator的配置
management:
endpoints:
enabled-by-default: true #默认开启所有监控端点
web:
exposure:
include: '*' #以web方式暴露所有端点
endpoint: #对某个端点的具体配置
health:
show-details: always
enabled: true
info:
enabled: true
beans:
enabled: true
metrics:
enabled: true
定制health
新建一个类,必须是以ComHealthIndicator结尾的类名,继承AbstractHealthIndicator
或者是用实现接口的方法(以下没有提及)
@Component
public class MyComHealthIndicator extends AbstractHealthIndicator {
/**
* 真实的检查方法
* @param builder
* @throws Exception
*/
@Override
protected void doHealthCheck(Health.Builder builder) throws Exception {
//mongodb。 获取连接进行测试
Map<String,Object> map = new HashMap<>();
// 检查完成
if(1 == 2){
// builder.up(); //健康
builder.status(Status.UP);
map.put("count",1);
map.put("ms",100);
}else {
// builder.down();
builder.status(Status.OUT_OF_SERVICE);
map.put("err","连接超时");
map.put("ms",3000);
}
builder.withDetail("code",100)
.withDetails(map);
}
}
只有全部组件都是 ‘up’ ,health端点才是up
定制info内容
或者实现InfoContributor接口,也可以自定义信息
@Component
public class ExampleInfoContributor implements InfoContributor {
@Override
public void contribute(Info.Builder builder) {
builder.withDetail("msg","你好")
.withDetail("hello","saving")
.withDetails(Collections.singletonMap("world","6666666600"));
}
}
定制Metrics信息
调用saveCity这个方法能被记录
定制自己的EndPoint
@Component
@Endpoint(id = "savingPoint")
public class MyServiceEndPoint {
@ReadOperation
public Map getDockerInfo(){
// 端点的读操作 "http://localhost:8080/actuator/savingPoint"
return Collections.singletonMap("info","docker started...");
}
@WriteOperation
private void restartDocker(){
System.out.println("docker restarted....");
}
}
定制的方法类型不重要,但是要有读、写注解