io.vertx.ext.dropwizard.impl.EndpointMetrics Maven / Gradle / Ivy
package io.vertx.ext.dropwizard.impl;
import com.codahale.metrics.Counter;
import com.codahale.metrics.Timer;
import io.vertx.core.spi.metrics.ClientMetrics;
import io.vertx.core.spi.observability.HttpRequest;
import io.vertx.core.spi.observability.HttpResponse;
import java.util.concurrent.TimeUnit;
/**
* @author Julien Viet
*/
public class EndpointMetrics implements ClientMetrics {
final HttpClientReporter reporter;
final Matcher uriMatcher;
final Counter openConnections;
final Timer usage;
final Timer ttfb;
final Counter inUse;
public EndpointMetrics(HttpClientReporter reporter, String name, Matcher uriMatcher) {
this.reporter = reporter;
this.openConnections = reporter.counter("endpoint", name, "open-netsockets");
this.usage = reporter.timer("endpoint", name, "usage");
this.ttfb = reporter.timer("endpoint", name, "ttfb");
this.inUse = reporter.counter("endpoint", name, "in-use");
this.uriMatcher = uriMatcher;
}
@Override
public HttpClientRequestMetric requestBegin(String uri, HttpRequest request) {
inUse.inc();
return new HttpClientRequestMetric(this, request.method(), request.uri());
}
@Override
public void requestEnd(HttpClientRequestMetric requestMetric, long bytesWritten) {
requestMetric.requestEnd = System.nanoTime();
}
@Override
public void requestReset(HttpClientRequestMetric requestMetric) {
inUse.inc();
}
@Override
public void responseBegin(HttpClientRequestMetric requestMetric, HttpResponse response) {
long waitTime = System.nanoTime() - requestMetric.requestEnd;
requestMetric.response = response;
ttfb.update(waitTime, TimeUnit.NANOSECONDS);
}
@Override
public void responseEnd(HttpClientRequestMetric requestMetric, long bytesRead) {
long duration = reporter.end(requestMetric, requestMetric.response.statusCode(), uriMatcher, null);
inUse.dec();
usage.update(duration, TimeUnit.NANOSECONDS);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy