java.lang.Object
io.prometheus.metrics.core.metrics.Metric
io.prometheus.metrics.core.metrics.MetricWithFixedMetadata
io.prometheus.metrics.core.metrics.Gauge
- All Implemented Interfaces:
DataPoint,GaugeDataPoint,TimerApi,io.prometheus.metrics.model.registry.Collector
Gauge metric.
Example usage:
Gauge currentActiveUsers = Gauge.builder()
.name("current_active_users")
.help("Number of users that are currently active")
.labelNames("region")
.register();
public void login(String region) {
currentActiveUsers.labelValues(region).inc();
// perform login
}
public void logout(String region) {
currentActiveUsers.labelValues(region).dec();
// perform logout
}
-
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 Gauge.Builderbuilder()static Gauge.Builderbuilder(io.prometheus.metrics.config.PrometheusProperties config) voidclear()Reset the metric (remove all data points).io.prometheus.metrics.model.snapshots.GaugeSnapshotcollect()protected io.prometheus.metrics.model.snapshots.GaugeSnapshotcollect(List<io.prometheus.metrics.model.snapshots.Labels> labels, List<io.prometheus.metrics.core.metrics.Gauge.DataPoint> metricData) labels and metricData have the same size. labels.get(i) are the labels for metricData.get(i).doubleget()Get the current value.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.Gauge.DataPointvoidinc(double amount) Addamount.voidincWithExemplar(double amount, io.prometheus.metrics.model.snapshots.Labels labels) Addamount, and create a custom exemplar with the given labels.voidinitLabelValues(String... labelValues) Initialize label values.protected booleanlabelValues(String... labelValues) protected io.prometheus.metrics.core.metrics.Gauge.DataPointvoidRemove the data point with the given label values.voidRemove the data points when the given function.voidset(double value) Set the gauge tovalue.voidsetWithExemplar(double value, io.prometheus.metrics.model.snapshots.Labels labels) Set the gauge tovalue, and create a custom exemplar with the given labels.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.GaugeDataPoint
dec, dec, decWithExemplar, decWithExemplar, inc, incWithExemplar, startTimerMethods inherited from interface io.prometheus.metrics.core.datapoints.TimerApi
time, time, timeChecked
-
Method Details
-
inc
public void inc(double amount) Description copied from interface:GaugeDataPointAddamount.- Specified by:
incin interfaceGaugeDataPoint
-
get
public double get()Description copied from interface:GaugeDataPointGet the current value.- Specified by:
getin interfaceGaugeDataPoint
-
incWithExemplar
public void incWithExemplar(double amount, io.prometheus.metrics.model.snapshots.Labels labels) Description copied from interface:GaugeDataPointAddamount, and create a custom exemplar with the given labels.- Specified by:
incWithExemplarin interfaceGaugeDataPoint
-
set
public void set(double value) Description copied from interface:GaugeDataPointSet the gauge tovalue.- Specified by:
setin interfaceGaugeDataPoint
-
setWithExemplar
public void setWithExemplar(double value, io.prometheus.metrics.model.snapshots.Labels labels) Description copied from interface:GaugeDataPointSet the gauge tovalue, and create a custom exemplar with the given labels.- Specified by:
setWithExemplarin interfaceGaugeDataPoint
-
collect
public io.prometheus.metrics.model.snapshots.GaugeSnapshot collect()- Specified by:
collectin interfaceio.prometheus.metrics.model.registry.Collector
-
collect
protected io.prometheus.metrics.model.snapshots.GaugeSnapshot collect(List<io.prometheus.metrics.model.snapshots.Labels> labels, List<io.prometheus.metrics.core.metrics.Gauge.DataPoint> metricData) labels and metricData have the same size. labels.get(i) are the labels for metricData.get(i). -
newDataPoint
protected io.prometheus.metrics.core.metrics.Gauge.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.Gauge.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)
-