All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.prometheus.metrics.model.snapshots.MetricMetadata Maven / Gradle / Ivy

There is a newer version: 1.0.1
Show newest version
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."); } } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy