java.lang.Object
io.prometheus.metrics.core.metrics.Metric
io.prometheus.metrics.core.metrics.MetricWithFixedMetadata
io.prometheus.metrics.core.metrics.StateSet
- All Implemented Interfaces:
DataPoint,StateSetDataPoint,io.prometheus.metrics.model.registry.Collector
StateSet metric. Example:
public enum Feature {
FEATURE_1("feature1"),
FEATURE_2("feature2");
private final String name;
Feature(String name) {
this.name = name;
}
// Override
public String toString() {
return name;
}
}
public static void main(String[] args) {
StateSet stateSet = StateSet.builder()
.name("feature_flags")
.help("Feature flags")
.labelNames("env")
.states(Feature.class)
.register();
stateSet.labelValues("dev").setFalse(FEATURE_1);
stateSet.labelValues("dev").setTrue(FEATURE_2);
}
The example above shows how to use a StateSet with an enum. You don't have to use enum, you can
use regular strings as well.-
Nested Class Summary
Nested Classes -
Field Summary
Fields inherited from class io.prometheus.metrics.core.metrics.MetricWithFixedMetadata
labelNamesFields inherited from class io.prometheus.metrics.core.metrics.Metric
constLabels -
Method Summary
Modifier and TypeMethodDescriptionstatic StateSet.Builderbuilder()static StateSet.Builderbuilder(io.prometheus.metrics.config.PrometheusProperties config) voidclear()Reset the metric (remove all data points).io.prometheus.metrics.model.snapshots.StateSetSnapshotcollect()protected io.prometheus.metrics.model.snapshots.StateSetSnapshotcollect(List<io.prometheus.metrics.model.snapshots.Labels> labels, List<io.prometheus.metrics.core.metrics.StateSet.DataPoint> metricDataList) labels and metricData have the same size. labels.get(i) are the labels for metricData.get(i).protected <P> PgetConfigProperty(io.prometheus.metrics.config.MetricsProperties[] properties, Function<io.prometheus.metrics.config.MetricsProperties, P> getter) protected io.prometheus.metrics.config.MetricsProperties[]getMetricProperties(io.prometheus.metrics.core.metrics.StatefulMetric.Builder<?, ?> builder, io.prometheus.metrics.config.PrometheusProperties prometheusProperties) protected io.prometheus.metrics.core.metrics.StateSet.DataPointvoidinitLabelValues(String... labelValues) Initialize label values.protected booleanlabelValues(String... labelValues) protected io.prometheus.metrics.core.metrics.StateSet.DataPointvoidRemove the data point with the given label values.voidRemove the data points when the given function.voidstatemust be one of the states from when theStateSetwas created withStateSet.Builder.states(String...).voidstatemust be one of the states from when theStateSetwas created withStateSet.Builder.states(String...).Methods inherited from class io.prometheus.metrics.core.metrics.MetricWithFixedMetadata
getMetadata, getPrometheusNameMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface io.prometheus.metrics.model.registry.Collector
collect, collect, collectMethods inherited from interface io.prometheus.metrics.core.datapoints.StateSetDataPoint
setFalse, setTrue
-
Method Details
-
collect
public io.prometheus.metrics.model.snapshots.StateSetSnapshot collect()- Specified by:
collectin interfaceio.prometheus.metrics.model.registry.Collector
-
collect
protected io.prometheus.metrics.model.snapshots.StateSetSnapshot collect(List<io.prometheus.metrics.model.snapshots.Labels> labels, List<io.prometheus.metrics.core.metrics.StateSet.DataPoint> metricDataList) labels and metricData have the same size. labels.get(i) are the labels for metricData.get(i). -
setTrue
Description copied from interface:StateSetDataPointstatemust be one of the states from when theStateSetwas created withStateSet.Builder.states(String...).- Specified by:
setTruein interfaceStateSetDataPoint
-
setFalse
Description copied from interface:StateSetDataPointstatemust be one of the states from when theStateSetwas created withStateSet.Builder.states(String...).- Specified by:
setFalsein interfaceStateSetDataPoint
-
newDataPoint
protected io.prometheus.metrics.core.metrics.StateSet.DataPoint newDataPoint() -
isExemplarsEnabled
protected boolean isExemplarsEnabled() -
builder
-
builder
-
initLabelValues
Initialize label values.Example: Imagine you have a counter for payments as follows
payment_transactions_total{payment_type="credit card"} 7.0 payment_transactions_total{payment_type="paypal"} 3.0Now, the data points for thepayment_typelabel values get initialized when they are first used, i.e. the first time you call
the data point with labelcounter.labelValues("paypal").inc();payment_type="paypal"will go from non-existent to having value1.0.In some cases this is confusing, and you want to have data points initialized on application start with an initial value of
0.0:payment_transactions_total{payment_type="credit card"} 0.0 payment_transactions_total{payment_type="paypal"} 0.0initLabelValues(...)can be used to initialize label value, so that the data points show up in the exposition format with an initial value of zero. -
labelValues
-
remove
Remove the data point with the given label values. See https://prometheus.io/docs/instrumenting/writing_clientlibs/#labels. -
removeIf
Remove the data points when the given function. -
clear
public void clear()Reset the metric (remove all data points). -
getNoLabels
protected io.prometheus.metrics.core.metrics.StateSet.DataPoint getNoLabels() -
getMetricProperties
protected io.prometheus.metrics.config.MetricsProperties[] getMetricProperties(io.prometheus.metrics.core.metrics.StatefulMetric.Builder<?, ?> builder, io.prometheus.metrics.config.PrometheusProperties prometheusProperties) -
getConfigProperty
protected <P> P getConfigProperty(io.prometheus.metrics.config.MetricsProperties[] properties, Function<io.prometheus.metrics.config.MetricsProperties, P> getter)
-