当邮件服务器未连接时,Jhipster健康终结点失败



JHipster/Spring引导提供了一个很好的端点/management/health,它在其中聚合数据库、磁盘和邮件等子系统的运行状况信息。不幸的是,当与邮件服务器的连接失败时,整个端点都会失败。所以你不会得到失败的信息。

我得到这样的扫射痕迹:

o.s.b.a.health.MailHealthIndicator       : Health check failed
com.sun.mail.util.MailConnectException: Couldn't connect to host, port: XXXX, NNNN25025; timeout -1
...
at org.springframework.boot.actuate.health.MailHealthIndicator.doHealthCheck(MailHealthIndicator.java:40)
at org.springframework.boot.actuate.health.AbstractHealthIndicator.health(AbstractHealthIndicator.java:43)
at org.springframework.boot.actuate.health.CompositeHealthIndicator.health(CompositeHealthIndicator.java:68)
at org.springframework.boot.actuate.endpoint.HealthEndpoint.invoke(HealthEndpoint.java:85)
at org.springframework.boot.actuate.endpoint.mvc.HealthMvcEndpoint.getCurrentHealth(HealthMvcEndpoint.java:177)
at org.springframework.boot.actuate.endpoint.mvc.HealthMvcEndpoint.getHealth(HealthMvcEndpoint.java:166)
at org.springframework.boot.actuate.endpoint.mvc.HealthMvcEndpoint.invoke(HealthMvcEndpoint.java:143)

这是弹簧套1.5.9我应该在哪里解决这个问题,以便捕获异常并返回错误状态?

您必须打开SMTP服务器或禁用对其的检查。

禁用对SMTP服务器的检查:

management.health.mail.enabled=false

禁用对所有服务器的检查:

management.health.defaults.enabled=false

有关详细信息,请参阅http://www.briansjavablog.com/2017/09/health-checks-metric-s-more-with-spring.html

我相信你可以用SpringBoot1.5.9版本的ExceptionHandler来处理这个错误,因为新版本没有这样的问题:

@ControllerAdvice
public class ExceptionController {
@ExceptionHandler(MailConnectException.class)
public ResponseEntity<?> mailExceptionHandler(MailConnectException e) {
// Do your treatment ...
} ... 
}

最新更新