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

com.aliyun.openservices.shade.io.prometheus.client.exemplars.ExemplarConfig Maven / Gradle / Ivy

package com.aliyun.openservices.shade.io.prometheus.client.exemplars;

/**
 * Static configuration for Exemplar behavior.
 */
public class ExemplarConfig {

  private static volatile boolean enabled = true;
  private static volatile HistogramExemplarSampler histogramExemplarSampler;
  private static volatile CounterExemplarSampler counterExemplarSampler;

  static {
    ExemplarSampler defaultExemplarSampler = new Tracer().initExemplarSampler();
    counterExemplarSampler = defaultExemplarSampler;
    histogramExemplarSampler = defaultExemplarSampler;
  }

  /**
   * Set the default exemplar sampler for Counters.
   */
  public static void setCounterExemplarSampler(CounterExemplarSampler counterExemplarSampler) {
    ExemplarConfig.counterExemplarSampler = counterExemplarSampler;
  }

  /**
   * Set the default exemplar sampler for Histograms.
   */
  public static void setHistogramExemplarSampler(HistogramExemplarSampler histogramExemplarSampler) {
    ExemplarConfig.histogramExemplarSampler = histogramExemplarSampler;
  }

  /**
   * Prevent metrics from loading exemplars from an {@link ExemplarSampler} by default.
   * 

* You can still enable individual metrics to load exemplars from an {@link ExemplarSampler} by calling the * metric builder's {@code withExemplars()} method, and you can still provide single exemplars explicitly * for individual observations with the {@code ...withExemplar()} methods. */ public static void disableExemplars() { enabled = false; } /** * Allow metrics to load exemplars from an {@link ExemplarSampler} by default. *

* You can still disallow individual metrics to load exemplars from an {@link ExemplarSampler} by calling * the metric builder's {@code withoutExemplars()} method. *

* Exemplars are enabled by default. This method is here so that you can temporarily {@link #disableExemplars()} * and then {@link #enableExemplars()} again. */ public static void enableExemplars() { enabled = true; } /** * @return the {@link CounterExemplarSampler} that is used by default in {@code Counter} metrics. */ public static CounterExemplarSampler getCounterExemplarSampler() { return counterExemplarSampler; } /** * @return the {@link HistogramExemplarSampler} that is used by default in {@code Histogram} metrics. */ public static HistogramExemplarSampler getHistogramExemplarSampler() { return histogramExemplarSampler; } /** * @return true by default, false if {@link #disableExemplars()} was called. */ public static boolean isExemplarsEnabled() { return enabled; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy