-
Notifications
You must be signed in to change notification settings - Fork 86
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Populate attributes from span tree? #88
Comments
how about this ?
MetrycsLayer::new(provider)
.with_collect_span(true)
.with_collect_span_filter(| field: &tracing::field::Field| -> bool { field.name() == "my_interest" }) If span collect is enabled, MetricsLayer iterates span during metrics event processing and adds the field of span to metrics attribute. |
@ymgyt Thanks for the quick reply. The proposal looks good 👍 I am trying to implement it locally but facing a problem:
I cannot figure out how to directly read the fields of spans when processing an event. I have some code like: if let Some(scope) = ctx.event_scope(event) {
for span in scope.from_root() {
// how to visit span's fields here...?
}
} So far by reading other libraries, my learning is that I need to store the fields in span extensions, then I can read from the extensions when processing an event - is this the only way? |
Yes, as I understand it, if you want to refer to the span's field later, you need to set it in the extension of each span. if let Some(scope) = ctx.event_scope(event) {
for span in scope.from_root() {
let mut extension = span.extensions_mut();
let Some(metrics_layer_ext) = extension.get_mut::<MetricsLayerExtension>() else {
continue;
}
// get metrics attribute from metrics_layer_ext
// and insert here https://github.com/tokio-rs/tracing-opentelemetry/blob/b2013d085cee229c83eb1558c3263e536186fb89/src/metrics.rs#L404
}
} There might be other ways, but as far as I know, that is the only way. |
Feature Request
Motivation
In tracing, I think it's common that the metadata about one trace are spread in different spans. Different layers in an application create spans, and tag the span with metadata they are responsible.
When a metric event is emitted, I'd like to be able to use those metadata that could be found in the span tree. Either flatten and keep all attributes in the tree and attach them to the metric event, or, even better, being able to somehow filter the attributes.
The text was updated successfully, but these errors were encountered: