mirror of
https://github.com/MarginaliaSearch/MarginaliaSearch.git
synced 2025-02-24 05:18:58 +00:00
data:image/s3,"s3://crabby-images/c765d/c765d5283f4176ac41b612e7ae83ed62e7ddf9a1" alt="Viktor Lofgren"
The new service 'status-service' will poll public endpoints periodically, and publish a basic read-only UI with the results, as well as publish the results to prometheus.
62 lines
1.9 KiB
Java
62 lines
1.9 KiB
Java
package nu.marginalia.status;
|
|
|
|
import io.prometheus.client.Counter;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import java.time.Duration;
|
|
import java.time.Instant;
|
|
import java.util.function.Supplier;
|
|
|
|
public class StatusMetric {
|
|
private final String name;
|
|
private final Supplier<Boolean> checker;
|
|
|
|
// We also push the metrics to Prometheus for additional statistics and monitoring
|
|
|
|
private static final Counter successCounter = Counter.build("external_status_metric_success", "Status Metric Success")
|
|
.labelNames("name")
|
|
.register();
|
|
private static final Counter failureCounter = Counter.build("external_status_metric_failure", "Status Metric Failure")
|
|
.labelNames("name")
|
|
.register();
|
|
|
|
private static final Logger logger = LoggerFactory.getLogger(StatusMetric.class);
|
|
|
|
public StatusMetric(String name, Supplier<Boolean> checker) {
|
|
this.name = name;
|
|
this.checker = checker;
|
|
}
|
|
|
|
public String getName() {
|
|
return name;
|
|
}
|
|
|
|
public MeasurementResult update() {
|
|
long startTime = System.nanoTime();
|
|
Instant now = Instant.now();
|
|
|
|
try {
|
|
if (checker.get()) {
|
|
long endTime = System.nanoTime();
|
|
successCounter.labels(name).inc();
|
|
return new MeasurementResult.Success(name, now, Duration.ofNanos(endTime - startTime));
|
|
}
|
|
} catch (Exception e) {
|
|
logger.error("Failed to check status metric: " + name, e);
|
|
}
|
|
|
|
failureCounter.labels(name).inc();
|
|
|
|
return new MeasurementResult.Failure(name, now);
|
|
}
|
|
|
|
public sealed interface MeasurementResult {
|
|
String name();
|
|
Instant when();
|
|
|
|
record Success(String name, Instant when, Duration callDuration) implements MeasurementResult {}
|
|
record Failure(String name, Instant when) implements MeasurementResult {}
|
|
}
|
|
}
|