All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.quarkus.micrometer.runtime.binder.vertx.VertxClientMetrics Maven / Gradle / Ivy

Go to download

Instrument the runtime and your application with dimensional metrics using Micrometer.

There is a newer version: 3.15.0
Show newest version
package io.quarkus.micrometer.runtime.binder.vertx;

import java.util.concurrent.atomic.LongAdder;
import java.util.function.Supplier;

import io.micrometer.core.instrument.Counter;
import io.micrometer.core.instrument.Gauge;
import io.micrometer.core.instrument.MeterRegistry;
import io.micrometer.core.instrument.Tags;
import io.micrometer.core.instrument.Timer;
import io.vertx.core.spi.metrics.ClientMetrics;

public class VertxClientMetrics
        implements ClientMetrics {

    private final String type;
    private final Timer processing;
    private final LongAdder current = new LongAdder();
    private final LongAdder queue = new LongAdder();
    private final Counter resetCount;
    private final Counter completed;
    private final Timer queueDelay;

    VertxClientMetrics(MeterRegistry registry, String type, Tags tags) {
        this.type = type;

        queueDelay = Timer.builder(name("queue.delay"))
                .description("Time spent in the waiting queue before being processed")
                .tags(tags)
                .register(registry);

        processing = Timer.builder(name("processing"))
                .description("Processing time, from request start to response end")
                .tags(tags)
                .register(registry);

        Gauge.builder(name("queue.size"), new Supplier() {
            @Override
            public Number get() {
                return queue.doubleValue();
            }
        })
                .description("Number of pending elements in the waiting queue")
                .tags(tags)
                .strongReference(true)
                .register(registry);

        Gauge.builder(name("current"), new Supplier() {
            @Override
            public Number get() {
                return current.doubleValue();
            }
        })
                .description("The number of requests currently handled by the client")
                .tags(tags)
                .strongReference(true)
                .register(registry);

        completed = Counter.builder(name("completed"))
                .description("Number of requests that have been handled by the client")
                .tags(tags)
                .register(registry);

        resetCount = Counter.builder(name("reset"))
                .description("Total number of resets")
                .tags(tags)
                .register(registry);
    }

    private String name(String suffix) {
        return type + "." + suffix;
    }

    @Override
    public EventTiming enqueueRequest() {
        queue.increment();
        return new EventTiming(queueDelay);
    }

    @Override
    public void dequeueRequest(EventTiming event) {
        queue.decrement();
        event.end();
    }

    @Override
    public EventTiming requestBegin(String uri, Object request) {
        current.increment();
        return new EventTiming(processing);
    }

    @Override
    public void requestEnd(EventTiming requestMetric) {
        // Ignoring request-alone metrics at the moment
    }

    @Override
    public void responseBegin(EventTiming requestMetric, Object response) {
        // Ignoring response-alone metrics at the moment
    }

    @Override
    public void requestReset(EventTiming event) {
        current.decrement();
        event.end();
        resetCount.increment();
    }

    @Override
    public void responseEnd(EventTiming event) {
        current.decrement();
        event.end();
        completed.increment();
    }

    @Override
    public void close() {
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy