io.micrometer.core.instrument.Metrics Maven / Gradle / Ivy
/*
* Copyright 2017 VMware, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.micrometer.core.instrument;
import io.micrometer.common.lang.Nullable;
import io.micrometer.core.instrument.composite.CompositeMeterRegistry;
import java.util.Collection;
import java.util.Map;
import java.util.concurrent.TimeUnit;
import java.util.function.ToDoubleFunction;
import java.util.function.ToLongFunction;
/**
* Generator of meters bound to a static global composite registry. For use especially in
* places where dependency injection of {@link MeterRegistry} is not possible for an
* instrumented type.
*
* @author Jon Schneider
*/
public class Metrics {
public static final CompositeMeterRegistry globalRegistry = new CompositeMeterRegistry();
private static final More more = new More();
/**
* Add a registry to the global composite registry.
* @param registry Registry to add.
*/
public static void addRegistry(MeterRegistry registry) {
globalRegistry.add(registry);
}
/**
* Remove a registry from the global composite registry. Removing a registry does not
* remove any meters that were added to it by previous participation in the global
* composite.
* @param registry Registry to remove.
*/
public static void removeRegistry(MeterRegistry registry) {
globalRegistry.remove(registry);
}
/**
* Tracks a monotonically increasing value.
* @param name The base metric name
* @param tags Sequence of dimensions for breaking down the name.
* @return A new or existing counter.
*/
public static Counter counter(String name, Iterable tags) {
return globalRegistry.counter(name, tags);
}
/**
* Tracks a monotonically increasing value.
* @param name The base metric name
* @param tags MUST be an even number of arguments representing key/value pairs of
* tags.
* @return A new or existing counter.
*/
public static Counter counter(String name, String... tags) {
return globalRegistry.counter(name, tags);
}
/**
* Measures the distribution of samples.
* @param name The base metric name
* @param tags Sequence of dimensions for breaking down the name.
* @return A new or existing distribution summary.
*/
public static DistributionSummary summary(String name, Iterable tags) {
return globalRegistry.summary(name, tags);
}
/**
* Measures the distribution of samples.
* @param name The base metric name
* @param tags MUST be an even number of arguments representing key/value pairs of
* tags.
* @return A new or existing distribution summary.
*/
public static DistributionSummary summary(String name, String... tags) {
return globalRegistry.summary(name, tags);
}
/**
* Measures the time taken for short tasks and the count of these tasks.
* @param name The base metric name
* @param tags Sequence of dimensions for breaking down the name.
* @return A new or existing timer.
*/
public static Timer timer(String name, Iterable tags) {
return globalRegistry.timer(name, tags);
}
/**
* Measures the time taken for short tasks and the count of these tasks.
* @param name The base metric name
* @param tags MUST be an even number of arguments representing key/value pairs of
* tags.
* @return A new or existing timer.
*/
public static Timer timer(String name, String... tags) {
return globalRegistry.timer(name, tags);
}
/**
* Access to less frequently used meter types and patterns.
* @return Access to additional meter types and patterns.
*/
public static More more() {
return more;
}
/**
* Register a gauge that reports the value of the object after the function
* {@code valueFunction} is applied. The registration will keep a weak reference to
* the object so it will not prevent garbage collection. Applying
* {@code valueFunction} on the object should be thread safe.
*
* If multiple gauges are registered with the same id, then the values will be
* aggregated and the sum will be reported. For example, registering multiple gauges
* for active threads in a thread pool with the same id would produce a value that is
* the overall number of active threads. For other behaviors, manage it on the user
* side and avoid multiple registrations.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @param obj Object used to compute a value.
* @param valueFunction Function that is applied on the value for the number.
* @param The type of the state object from which the gauge value is extracted.
* @return The number that was passed in so the registration can be done as part of an
* assignment statement.
*/
@Nullable
public static T gauge(String name, Iterable tags, T obj, ToDoubleFunction valueFunction) {
return globalRegistry.gauge(name, tags, obj, valueFunction);
}
/**
* Register a gauge that reports the value of the {@link java.lang.Number}.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @param number Thread-safe implementation of {@link Number} used to access the
* value.
* @param The type of the state object from which the gauge value is extracted.
* @return The number that was passed in so the registration can be done as part of an
* assignment statement.
*/
@Nullable
public static T gauge(String name, Iterable tags, T number) {
return globalRegistry.gauge(name, tags, number);
}
/**
* Register a gauge that reports the value of the {@link java.lang.Number}.
* @param name Name of the gauge being registered.
* @param number Thread-safe implementation of {@link Number} used to access the
* value.
* @param The type of the state object from which the gauge value is extracted.
* @return The number that was passed in so the registration can be done as part of an
* assignment statement.
*/
@Nullable
public static T gauge(String name, T number) {
return globalRegistry.gauge(name, number);
}
/**
* Register a gauge that reports the value of the object.
* @param name Name of the gauge being registered.
* @param obj Object used to compute a value.
* @param valueFunction Function that is applied on the value for the number.
* @param The type of the state object from which the gauge value is extracted.F
* @return The number that was passed in so the registration can be done as part of an
* assignment statement.
*/
@Nullable
public static T gauge(String name, T obj, ToDoubleFunction valueFunction) {
return globalRegistry.gauge(name, obj, valueFunction);
}
/**
* Register a gauge that reports the size of the {@link java.util.Collection}. The
* registration will keep a weak reference to the collection so it will not prevent
* garbage collection. The collection implementation used should be thread safe. Note
* that calling {@link java.util.Collection#size()} can be expensive for some
* collection implementations and should be considered before registering.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @param collection Thread-safe implementation of {@link Collection} used to access
* the value.
* @param The type of the state object from which the gauge value is extracted.
* @return The number that was passed in so the registration can be done as part of an
* assignment statement.
*/
@Nullable
public static > T gaugeCollectionSize(String name, Iterable tags, T collection) {
return globalRegistry.gaugeCollectionSize(name, tags, collection);
}
/**
* Register a gauge that reports the size of the {@link java.util.Map}. The
* registration will keep a weak reference to the collection so it will not prevent
* garbage collection. The collection implementation used should be thread safe. Note
* that calling {@link java.util.Map#size()} can be expensive for some collection
* implementations and should be considered before registering.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @param map Thread-safe implementation of {@link Map} used to access the value.
* @param The type of the state object from which the gauge value is extracted.
* @return The number that was passed in so the registration can be done as part of an
* assignment statement.
*/
@Nullable
public static > T gaugeMapSize(String name, Iterable tags, T map) {
return globalRegistry.gaugeMapSize(name, tags, map);
}
/**
* Additional, less commonly used meter types.
*/
public static class More {
/**
* Measures the time taken for long tasks.
* @param name Name of the gauge being registered.
* @param tags MUST be an even number of arguments representing key/value pairs of
* tags.
* @return A new or existing long task timer.
*/
public LongTaskTimer longTaskTimer(String name, String... tags) {
return globalRegistry.more().longTaskTimer(name, tags);
}
/**
* Measures the time taken for long tasks.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @return A new or existing long task timer.
*/
public LongTaskTimer longTaskTimer(String name, Iterable tags) {
return globalRegistry.more().longTaskTimer(name, tags);
}
/**
* Tracks a monotonically increasing value, automatically incrementing the counter
* whenever the value is observed.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @param obj State object used to compute a value.
* @param countFunction Function that produces a monotonically increasing counter
* value from the state object.
* @param The type of the state object from which the counter value is
* extracted.
* @return A new or existing function counter.
*/
public FunctionCounter counter(String name, Iterable tags, T obj, ToDoubleFunction countFunction) {
return globalRegistry.more().counter(name, tags, obj, countFunction);
}
/**
* Tracks a number, maintaining a weak reference on it.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @param number A monotonically increasing number to track.
* @param The type of the state object from which the counter value is
* extracted.
* @return A new or existing function counter.
*/
public FunctionCounter counter(String name, Iterable tags, T number) {
return globalRegistry.more().counter(name, tags, number);
}
/**
* A gauge that tracks a time value, to be scaled to the monitoring system's base
* time unit.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @param obj State object used to compute a value.
* @param timeFunctionUnit The base unit of time produced by the total time
* function.
* @param timeFunction Function that produces a time value from the state object.
* This value may increase and decrease over time.
* @param The type of the state object from which the gauge value is
* extracted.
* @return A new or existing time gauge.
*/
public TimeGauge timeGauge(String name, Iterable tags, T obj, TimeUnit timeFunctionUnit,
ToDoubleFunction timeFunction) {
return globalRegistry.more().timeGauge(name, tags, obj, timeFunctionUnit, timeFunction);
}
/**
* A timer that tracks monotonically increasing functions for count and totalTime.
* @param name Name of the gauge being registered.
* @param tags Sequence of dimensions for breaking down the name.
* @param obj State object used to compute a value.
* @param countFunction Function that produces a monotonically increasing counter
* value from the state object.
* @param totalTimeFunction Function that produces a monotonically increasing
* total time value from the state object.
* @param totalTimeFunctionUnit The base unit of time produced by the total time
* function.
* @param The type of the state object from which the function values are
* extracted.
* @return A new or existing function timer.
*/
public FunctionTimer timer(String name, Iterable tags, T obj, ToLongFunction countFunction,
ToDoubleFunction totalTimeFunction, TimeUnit totalTimeFunctionUnit) {
return globalRegistry.more()
.timer(name, tags, obj, countFunction, totalTimeFunction, totalTimeFunctionUnit);
}
}
}