io.prometheus.metrics.model.snapshots.MetricMetadata Maven / Gradle / Ivy
package io.prometheus.metrics.model.snapshots;
/**
* Immutable container for metric metadata: name, help, unit.
*/
public final class MetricMetadata {
/**
* Name without suffix.
*
* For example, the name for a counter "http_requests_total" is "http_requests".
* The name of an info called "jvm_info" is "jvm".
*
* We allow dots in label names. Dots are automatically replaced with underscores in Prometheus
* exposition formats. However, if metrics from this library are exposed in OpenTelemetry
* format dots are retained.
*
* See {@link #MetricMetadata(String, String, Unit)} for more info on naming conventions.
*/
private final String name;
/**
* Same as name, except if name contains dots, then the prometheusName is {@code name.replace(".", "_")}.
*/
private final String prometheusName;
/**
* optional, may be {@code null}.
*/
private final String help;
/**
* optional, may be {@code null}.
*/
private final Unit unit;
/**
* See {@link #MetricMetadata(String, String, Unit)}
*/
public MetricMetadata(String name) {
this(name, null, null);
}
/**
* See {@link #MetricMetadata(String, String, Unit)}
*/
public MetricMetadata(String name, String help) {
this(name, help, null);
}
/**
* Constructor.
* @param name must not be {@code null}. {@link PrometheusNaming#isValidMetricName(String) isValidMetricName(name)}
* must be {@code true}. Use {@link PrometheusNaming#sanitizeMetricName(String)} to convert arbitrary
* strings into valid names.
* @param help optional. May be {@code null}.
* @param unit optional. May be {@code null}.
*/
public MetricMetadata(String name, String help, Unit unit) {
this.name = name;
this.help = help;
this.unit = unit;
validate();
this.prometheusName = name.contains(".") ? PrometheusNaming.prometheusName(name) : name;
}
/**
* The name does not include the {@code _total} suffix for counter metrics
* or the {@code _info} suffix for Info metrics.
*
* The name may contain dots. Use {@link #getPrometheusName()} to get the name in Prometheus format,
* i.e. with dots replaced by underscores.
*/
public String getName() {
return name;
}
/**
* Same as {@link #getName()} but with dots replaced by underscores.
*
* This is used by Prometheus exposition formats.
*/
public String getPrometheusName() {
return prometheusName;
}
public String getHelp() {
return help;
}
public boolean hasUnit() {
return unit != null;
}
public Unit getUnit() {
return unit;
}
private void validate() {
if (name == null) {
throw new IllegalArgumentException("Missing required field: name is null");
}
String error = PrometheusNaming.validateMetricName(name);
if (error != null) {
throw new IllegalArgumentException("'" + name + "': Illegal metric name. " + error
+ " Call " + PrometheusNaming.class.getSimpleName() + ".sanitizeMetricName(name) to avoid this error.");
}
if (hasUnit()) {
if (!name.endsWith("_" + unit) && !name.endsWith("." + unit)) {
throw new IllegalArgumentException("'" + name + "': Illegal metric name. If the unit is non-null, the name must end with the unit: _" + unit + "."
+ " Call " + PrometheusNaming.class.getSimpleName() + ".sanitizeMetricName(name, unit) to avoid this error.");
}
}
}
}