io.zeebe.gateway.impl.probes.health.ClusterAwarenessHealthIndicator Maven / Gradle / Ivy
/*
* Copyright Camunda Services GmbH and/or licensed to Camunda Services GmbH under
* one or more contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright ownership.
* Licensed under the Zeebe Community License 1.0. You may not use this file
* except in compliance with the Zeebe Community License 1.0.
*/
package io.zeebe.gateway.impl.probes.health;
import static java.util.Objects.requireNonNull;
import io.zeebe.gateway.impl.broker.cluster.BrokerClusterState;
import java.util.Optional;
import java.util.function.Supplier;
import org.springframework.boot.actuate.health.Health;
import org.springframework.boot.actuate.health.HealthIndicator;
/**
* Health indicator that signals whether the gateway is aware of any nodes in the cluster. If the
* gateway is not aware of any nodes this indicates a potential network topology problem
*/
public class ClusterAwarenessHealthIndicator implements HealthIndicator {
private final Supplier> clusterStateSupplier;
public ClusterAwarenessHealthIndicator(
final Supplier> clusterStateSupplier) {
this.clusterStateSupplier = requireNonNull(clusterStateSupplier);
}
@Override
public Health health() {
final var optClusterState = clusterStateSupplier.get();
if (optClusterState.isEmpty()) {
return Health.down().build();
} else {
if (optClusterState.get().getBrokers().isEmpty()) {
return Health.down().build();
} else {
return Health.up().build();
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy