Skip to content

Commit

Permalink
fix: some health checks are always UP even when a counter hits limit #…
Browse files Browse the repository at this point in the history
  • Loading branch information
jsenko committed Nov 22, 2023
1 parent 8556162 commit 17df6fb
Show file tree
Hide file tree
Showing 4 changed files with 25 additions and 27 deletions.
Original file line number Diff line number Diff line change
@@ -1,13 +1,12 @@
package io.apicurio.registry.metrics.health.liveness;

import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Default;
import jakarta.inject.Inject;

import io.apicurio.common.apps.config.Info;
import io.apicurio.registry.metrics.health.AbstractErrorCounterHealthCheck;

import jakarta.annotation.PostConstruct;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Default;
import jakarta.inject.Inject;
import org.eclipse.microprofile.config.inject.ConfigProperty;
import org.eclipse.microprofile.health.HealthCheck;
import org.eclipse.microprofile.health.HealthCheckResponse;
Expand Down Expand Up @@ -68,7 +67,7 @@ public synchronized HealthCheckResponse call() {
return HealthCheckResponse.builder()
.name("PersistenceExceptionLivenessCheck")
.withData("errorCount", errorCounter)
.up()
.status(up)
.build();
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,12 @@
package io.apicurio.registry.metrics.health.liveness;

import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Default;
import jakarta.inject.Inject;

import io.apicurio.common.apps.config.Info;
import io.apicurio.registry.metrics.health.AbstractErrorCounterHealthCheck;

import jakarta.annotation.PostConstruct;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Default;
import jakarta.inject.Inject;
import org.eclipse.microprofile.config.inject.ConfigProperty;
import org.eclipse.microprofile.health.HealthCheck;
import org.eclipse.microprofile.health.HealthCheckResponse;
Expand Down Expand Up @@ -66,7 +65,7 @@ public synchronized HealthCheckResponse call() {
return HealthCheckResponse.builder()
.name("ResponseErrorLivenessCheck")
.withData("errorCount", errorCounter)
.up()
.status(up)
.build();
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,21 +1,20 @@
package io.apicurio.registry.metrics.health.readiness;

import java.time.Duration;

import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Default;
import jakarta.inject.Inject;

import io.apicurio.common.apps.config.Info;
import io.apicurio.registry.metrics.health.AbstractErrorCounterHealthCheck;

import jakarta.annotation.PostConstruct;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Default;
import jakarta.inject.Inject;
import org.eclipse.microprofile.config.inject.ConfigProperty;
import org.eclipse.microprofile.health.HealthCheck;
import org.eclipse.microprofile.health.HealthCheckResponse;
import org.eclipse.microprofile.health.Liveness;
import org.slf4j.Logger;

import java.time.Duration;

/**
* Fail readiness check if the duration of processing a artifactStore operation is too high.
*
Expand Down Expand Up @@ -75,7 +74,7 @@ public synchronized HealthCheckResponse call() {
return HealthCheckResponse.builder()
.name("PersistenceTimeoutReadinessCheck")
.withData("errorCount", errorCounter)
.up()
.status(up)
.build();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,6 @@
import io.apicurio.registry.metrics.health.AbstractErrorCounterHealthCheck;

import jakarta.annotation.PostConstruct;
import org.eclipse.microprofile.config.inject.ConfigProperty;
import org.eclipse.microprofile.health.HealthCheck;
import org.eclipse.microprofile.health.HealthCheckResponse;
import org.eclipse.microprofile.health.Readiness;
import org.slf4j.Logger;
import java.time.Duration;
import java.time.Instant;
import java.time.format.DateTimeParseException;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Default;
import jakarta.enterprise.inject.Instance;
Expand All @@ -21,6 +13,15 @@
import jakarta.ws.rs.container.ContainerResponseContext;
import jakarta.ws.rs.container.ContainerResponseFilter;
import jakarta.ws.rs.ext.Provider;
import org.eclipse.microprofile.config.inject.ConfigProperty;
import org.eclipse.microprofile.health.HealthCheck;
import org.eclipse.microprofile.health.HealthCheckResponse;
import org.eclipse.microprofile.health.Readiness;
import org.slf4j.Logger;

import java.time.Duration;
import java.time.Instant;
import java.time.format.DateTimeParseException;

/**
* @author Jakub Senko <em>m@jsenko.net</em>
Expand Down Expand Up @@ -95,7 +96,7 @@ public void filter(ContainerRequestContext requestContext, ContainerResponseCont
log.error("Value '{}' of header '{}' is the wrong format!", requestStart, HEADER_NAME);
}

} else if (responseContext.getStatus() != 404){
} else if (responseContext.getStatus() != 404) {
log.warn("Expected header '{}' not found.", HEADER_NAME);
}
}
Expand All @@ -106,7 +107,7 @@ public synchronized HealthCheckResponse call() {
return HealthCheckResponse.builder()
.name("ResponseTimeoutReadinessCheck")
.withData("errorCount", errorCounter)
.up()
.status(up)
.build();
}
}

0 comments on commit 17df6fb

Please sign in to comment.