io.prometheus.metrics.model.snapshots.DataPointSnapshot Maven / Gradle / Ivy
package io.prometheus.metrics.model.snapshots;
public abstract class DataPointSnapshot {
private final Labels labels;
private final long createdTimestampMillis;
private final long scrapeTimestampMillis;
protected DataPointSnapshot(Labels labels, long createdTimestampMillis, long scrapeTimestampMillis) {
this.labels = labels;
this.createdTimestampMillis = createdTimestampMillis;
this.scrapeTimestampMillis = scrapeTimestampMillis;
validate();
}
private void validate() {
if (labels == null) {
throw new IllegalArgumentException("Labels cannot be null. Use Labels.EMPTY if there are no labels.");
}
if (createdTimestampMillis < 0) {
throw new IllegalArgumentException("Created timestamp cannot be negative. Use 0 if the metric doesn't have a created timestamp.");
}
if (scrapeTimestampMillis < 0) {
throw new IllegalArgumentException("Scrape timestamp cannot be negative. Use 0 to indicate that the Prometheus server should set the scrape timestamp.");
}
if (hasCreatedTimestamp() && hasScrapeTimestamp()) {
if (scrapeTimestampMillis < createdTimestampMillis) {
throw new IllegalArgumentException("The scrape timestamp cannot be before the created timestamp");
}
}
}
public Labels getLabels() {
return labels;
}
public boolean hasScrapeTimestamp() {
return scrapeTimestampMillis != 0L;
}
/**
* This will only return a reasonable value if {@link #hasScrapeTimestamp()} is true.
*/
public long getScrapeTimestampMillis() {
return scrapeTimestampMillis;
}
public boolean hasCreatedTimestamp() {
return createdTimestampMillis != 0L;
}
/**
* This will only return a reasonable value if {@link #hasCreatedTimestamp()} is true.
* Some metrics like Gauge don't have created timestamps. For these metrics {@link #hasCreatedTimestamp()}
* is always false.
*/
public long getCreatedTimestampMillis() {
return createdTimestampMillis;
}
public static abstract class Builder> {
protected Labels labels = Labels.EMPTY;
protected long scrapeTimestampMillis = 0L;
public T labels(Labels labels) {
this.labels = labels;
return self();
}
/**
* In most cases you should not set a scrape timestamp,
* because the scrape timestamp is set by the Prometheus server during scraping.
* Exceptions include mirroring metrics with given timestamps from other metric sources.
*/
public T scrapeTimestampMillis(long scrapeTimestampMillis) {
this.scrapeTimestampMillis = scrapeTimestampMillis;
return self();
}
protected abstract T self();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy