默认情况下,Eureka客户端是使用心跳和服务端通信来判断客户端是否存活,在某些场景下,例如MongoDB出现了异常,但是你的应用进程还是存在的,这就以为着应用可以继续通过心跳上报,保持应用自己的信息在Eureka中不被剔除掉。
Spring Boot Actuator提供了/actuator/health端点,该端点可展示应用程序的健康信息,当MongoDB异常时,/actuator/health端点的状态就会变为DOWN,由于应用本身确实处于存活状态,但是MongoDB的异常会影响某些功能,当请求达到应用之后会发生操作失败的情况。
在这种情况下,我们希望可以将健康信息传递给Eureka服务端,这样Eureka中就能及时将应用的实例信息下线,隔离正常请求,防止出错。通过配置如下内容开启健康检查:
eureka.client.healthcheck.enable=true
下面通过扩展健康检查的端点来模拟异常情况,定义一个扩展端点,将状态设置为DOWN,代码如下
import org.springframework.boot.actuate.health.AbstractHealthIndicator;
import org.springframework.boot.actuate.health.Health;
import org.springframework.stereotype.Component;
@Component
public class CustomHealthIndicator extends AbstractHealthIndicator {
@Override
protected v