Skip to content

Commit

Permalink
Return consistent Meter for a given MeterProvider (#1351)
Browse files Browse the repository at this point in the history
  • Loading branch information
jtescher committed Nov 13, 2023
1 parent f6fb7a6 commit 3ed8998
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 10 deletions.
1 change: 1 addition & 0 deletions opentelemetry-sdk/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
### Fixed

- Fix metric export corruption if gauges have not received a last value. (#1363)
- Return consistent `Meter` for a given scope from `MeterProvider`. (#1351)

## v0.21.0

Expand Down
31 changes: 21 additions & 10 deletions opentelemetry-sdk/src/metrics/meter_provider.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
use core::fmt;
use std::{
borrow::Cow,
collections::HashMap,
sync::{
atomic::{AtomicBool, Ordering},
Arc,
Arc, Mutex,
},
};

use opentelemetry::{
metrics::{noop::NoopMeterCore, InstrumentProvider, Meter as ApiMeter, MetricsError, Result},
metrics::{noop::NoopMeterCore, Meter as ApiMeter, MetricsError, Result},
KeyValue,
};

Expand All @@ -26,6 +27,7 @@ use super::{meter::Meter as SdkMeter, pipeline::Pipelines, reader::MetricReader,
#[derive(Clone, Debug)]
pub struct MeterProvider {
pipes: Arc<Pipelines>,
meters: Arc<Mutex<HashMap<Scope, Arc<SdkMeter>>>>,
is_shutdown: Arc<AtomicBool>,
}

Expand Down Expand Up @@ -121,15 +123,23 @@ impl opentelemetry::metrics::MeterProvider for MeterProvider {
schema_url: Option<impl Into<Cow<'static, str>>>,
attributes: Option<Vec<KeyValue>>,
) -> ApiMeter {
let inst_provider: Arc<dyn InstrumentProvider + Send + Sync> =
if !self.is_shutdown.load(Ordering::Relaxed) {
let scope = Scope::new(name, version, schema_url, attributes);
Arc::new(SdkMeter::new(scope, self.pipes.clone()))
} else {
Arc::new(NoopMeterCore::new())
};
if self.is_shutdown.load(Ordering::Relaxed) {
return ApiMeter::new(Arc::new(NoopMeterCore::new()));
}

let scope = Scope::new(name, version, schema_url, attributes);

ApiMeter::new(inst_provider)
if let Ok(mut meters) = self.meters.lock() {
let meter = meters
.entry(scope)
.or_insert_with_key(|scope| {
Arc::new(SdkMeter::new(scope.clone(), self.pipes.clone()))
})
.clone();
ApiMeter::new(meter)
} else {
ApiMeter::new(Arc::new(NoopMeterCore::new()))
}
}
}

Expand Down Expand Up @@ -184,6 +194,7 @@ impl MeterProviderBuilder {
self.readers,
self.views,
)),
meters: Default::default(),
is_shutdown: Arc::new(AtomicBool::new(false)),
}
}
Expand Down

0 comments on commit 3ed8998

Please sign in to comment.