io.quarkus.micrometer.runtime.binder.vertx.VertxPoolMetrics Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of quarkus-micrometer Show documentation
Show all versions of quarkus-micrometer Show documentation
Instrument the runtime and your application with dimensional metrics using Micrometer.
package io.quarkus.micrometer.runtime.binder.vertx;
import java.util.concurrent.atomic.AtomicReference;
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.Tag;
import io.micrometer.core.instrument.Tags;
import io.micrometer.core.instrument.Timer;
import io.vertx.core.spi.metrics.PoolMetrics;
/**
* Adaptation of the Vert.x Pool Metrics implementation for Quarkus Micrometer.
*/
public class VertxPoolMetrics implements PoolMetrics {
private final String poolType;
private final int maxPoolSize;
private final Timer usage;
private final AtomicReference ratio = new AtomicReference<>();
private final LongAdder current = new LongAdder();
private final LongAdder queue = new LongAdder();
private final Counter completed;
private final Counter rejected;
private final Timer queueDelay;
VertxPoolMetrics(MeterRegistry registry, String poolType, String poolName, int maxPoolSize) {
this.poolType = poolType;
this.maxPoolSize = maxPoolSize;
Tags tags = Tags.of(Tag.of("pool.type", poolType), Tag.of("pool.name", poolName));
queueDelay = Timer.builder(name("queue.delay"))
.description("Time spent in the waiting queue before being processed")
.tags(tags)
.register(registry);
usage = Timer.builder(name("usage"))
.description("Time spent using resources from the pool")
.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("active"), new Supplier() {
@Override
public Number get() {
return current.doubleValue();
}
})
.description("The number of resources from the pool currently used")
.tags(tags)
.strongReference(true)
.register(registry);
if (maxPoolSize > 0) {
Gauge.builder(name("idle"), new Supplier() {
@Override
public Number get() {
return maxPoolSize - current.doubleValue();
}
})
.description("The number of resources from the pool currently used")
.tags(tags)
.strongReference(true)
.register(registry);
Gauge.builder(name("ratio"), ratio::get)
.description("Pool usage ratio")
.tags(tags)
.strongReference(true)
.register(registry);
}
completed = Counter.builder(name("completed"))
.description("Number of times resources from the pool have been acquired")
.tags(tags)
.register(registry);
rejected = Counter.builder(name("rejected"))
.description("Number of times submissions to the pool have been rejected")
.tags(tags)
.register(registry);
}
private String name(String suffix) {
return poolType + ".pool." + suffix;
}
@Override
public EventTiming submitted() {
queue.increment();
return new EventTiming(queueDelay);
}
@Override
public void rejected(EventTiming submitted) {
queue.decrement();
rejected.increment();
submitted.end();
}
@Override
public EventTiming begin(EventTiming submitted) {
queue.decrement();
submitted.end();
current.increment();
computeRatio(current.longValue());
return new EventTiming(usage);
}
@Override
public void end(EventTiming timer, boolean succeeded) {
current.decrement();
computeRatio(current.longValue());
timer.end();
completed.increment();
}
@Override
public void close() {
}
private void computeRatio(long inUse) {
if (maxPoolSize > 0) {
ratio.set((double) inUse / maxPoolSize);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy