Skip to content

Commit

Permalink
Adds prometheus builder support for specifying bucket count
Browse files Browse the repository at this point in the history
  • Loading branch information
cparratto committed Feb 14, 2024
1 parent 2085cb1 commit 640663e
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 7 deletions.
19 changes: 19 additions & 0 deletions metrics-exporter-prometheus/src/builder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,7 @@ pub struct PrometheusBuilder {
allowed_addresses: Option<Vec<IpNet>>,
quantiles: Vec<Quantile>,
bucket_duration: Option<Duration>,
bucket_count: Option<u32>,
buckets: Option<Vec<f64>>,
bucket_overrides: Option<HashMap<Matcher, Vec<f64>>>,
idle_timeout: Option<Duration>,
Expand All @@ -122,6 +123,7 @@ impl PrometheusBuilder {
allowed_addresses: None,
quantiles,
bucket_duration: None,
bucket_count: None,
buckets: None,
bucket_overrides: None,
idle_timeout: None,
Expand Down Expand Up @@ -257,6 +259,22 @@ impl PrometheusBuilder {
Ok(self)
}

/// Sets the default bucket count for rolling summaries
///
/// Count number buckets are created to store summary information
///
/// ## Errors
///
/// If `value` less than 1 error will be thrown
pub fn set_bucket_count(mut self, count: u32) -> Result<Self, BuildError> {
if count == 0 {
return Err(BuildError::ZeroBucketCount);
}

self.bucket_count = Some(count);
Ok(self)
}

/// Sets the buckets to use when rendering histograms.
///
/// Buckets values represent the higher bound of each buckets. If buckets are set, then all
Expand Down Expand Up @@ -556,6 +574,7 @@ impl PrometheusBuilder {
self.quantiles,
self.bucket_duration,
self.buckets,
self.bucket_count,
self.bucket_overrides,
),
descriptions: RwLock::new(HashMap::new()),
Expand Down
4 changes: 4 additions & 0 deletions metrics-exporter-prometheus/src/common.rs
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,10 @@ pub enum BuildError {
/// Bucket duration cannot be zero
#[error("bucket durations cannot be set to zero")]
ZeroBucketDuration,

/// Bucket count cannot be zero
#[error("bucket count cannot be set to zero")]
ZeroBucketCount,
}

pub struct Snapshot {
Expand Down
21 changes: 14 additions & 7 deletions metrics-exporter-prometheus/src/distribution.rs
Original file line number Diff line number Diff line change
Expand Up @@ -36,13 +36,14 @@ impl Distribution {
/// Creates a summary distribution.
pub fn new_summary(
quantiles: Arc<Vec<Quantile>>,
bucket_duration: Option<Duration>,
bucket_duration: Duration,
bucket_count: u32,
) -> Distribution {
let summary = bucket_duration.map_or(
RollingSummary::new(NonZeroU32::new(3).unwrap(), Duration::from_secs(20)),
|duration| RollingSummary::new(NonZeroU32::new(3).unwrap(), duration),
);
Distribution::Summary(summary, quantiles, 0.0)
Distribution::Summary(
RollingSummary::new(NonZeroU32::new(bucket_count).unwrap(), bucket_duration),
quantiles,
0.0,
)
}

/// Records the given `samples` in the current distribution.
Expand All @@ -67,6 +68,7 @@ pub struct DistributionBuilder {
quantiles: Arc<Vec<Quantile>>,
buckets: Option<Vec<f64>>,
bucket_duration: Option<Duration>,
bucket_count: Option<u32>,
bucket_overrides: Option<Vec<(Matcher, Vec<f64>)>>,
}

Expand All @@ -76,12 +78,14 @@ impl DistributionBuilder {
quantiles: Vec<Quantile>,
bucket_duration: Option<Duration>,
buckets: Option<Vec<f64>>,
bucket_count: Option<u32>,
bucket_overrides: Option<HashMap<Matcher, Vec<f64>>>,
) -> DistributionBuilder {
DistributionBuilder {
quantiles: Arc::new(quantiles),
bucket_duration,
buckets,
bucket_count,
bucket_overrides: bucket_overrides.map(|entries| {
let mut matchers = entries.into_iter().collect::<Vec<_>>();
matchers.sort_by(|a, b| a.0.cmp(&b.0));
Expand All @@ -104,7 +108,10 @@ impl DistributionBuilder {
return Distribution::new_histogram(buckets);
}

Distribution::new_summary(self.quantiles.clone(), self.bucket_duration)
let b_duration = self.bucket_duration.map_or(Duration::from_secs(20), |d| d);
let b_count = self.bucket_count.map_or(3, |c| c);

Distribution::new_summary(self.quantiles.clone(), b_duration, b_count)
}

/// Returns the distribution type for the given metric key.
Expand Down

0 comments on commit 640663e

Please sign in to comment.