微服务往往依赖诸多中间件例如数据库、消息队列等,也依赖其他微服务。当微服务不可用时,例如是由于数据库不可用引起的,我们需要通过日志系统或监控面板将不可用的详细原因记录下或展示出来:磁盘空间满报错?数据库访问用户名密码变更?数据库访问权限变化?而不仅仅是一个报错不可用的状态,这会对快速定位问题和解决故障大有裨益。
健康检查(HealthCheck)提供了一套扩展机制,用户可以自定义检查点,探测微服务内部核心依赖是否可用,如果不可用,将详细信息暴露出来:
实现自定义HealthCheck
Java Chassis HealthCheck使用起来非常简单,只需要继承
org.apache.servicecomb.foundation.metrics.health.HealthChecker
接口,并实现方法:
public class MySqlHealthChecker implements HealthChecker {
@Override
public String getName() {
return "mysql";
@Override
public HealthCheckResult check() {
//add your health check code here
Connection connection = null;
try {
connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/test_db?useSSL=false", "root", "pwd");
return new HealthCheckResult(true, "local mysql health check", "");
} catch (SQLException e) {
LOG.error("Cannot connect the localhost mysql. ", e);
return new HealthCheckResult(false, "local mysql health check", e.toString());
} finally {
if (connection != null) {
try {
connection.close();
} catch (SQLException e) {
LOG.error("Close connect the localhost mysql error. ", e);
然后使用SPI的方式加载它,具体为在resource/META-INF/services
下创建org.apache.servicecomb.foundation.metrics.health.HealthChecker
文件,然后写入实现的HealthCheck类名即可,例如:
org.apache.servicecomb.samples.metrics.extendhealthcheck.MySqlHealthChecker
验证实现的HealthCheck
启动微服务后,HealthCheck默认以Rest方式发布,发布地址与servicecomb.rest.address
一致,如果在microservice.yaml
中设置的配置为:
servicecomb:
rest:
address: 0.0.0.0:8080
那么就可以通过访问http://localhost:8080/health 获取检查结果,以及访问http://localhost:8080/health/detail 获取所有的检查项结果明细。
HealthCheck的默认Rest发布实现在metrics-core中,因此需要增加此依赖;
/health为所有HealthCheck的最终结果,true或false,只要有任何一个HealthCheck的healthy结果为false,那么就会是false。
我们已经提供了一个例子作为参考,代码在samples/metrics-extend-healthcheck中。