-
Notifications
You must be signed in to change notification settings - Fork 4.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
.NET 9.0
Native Trace Instrumentation Support for HttpClient as per OTel specification
#93019
Comments
Tagging subscribers to this area: @dotnet/ncl Issue DetailsCurrent StateCurrently, users depend on the instrumentation library provided by the OpenTelemetry .NET repository to enable the enrichment of activities created during HttpClient requests, following the OpenTelemetry specification. This instrumentation library enriches activities by subscribing to DiagnosticSource events generated by HttpClient. However, this approach has certain limitation. Feature RequestWe are requesting the addition of native instrumentation support for HttpClient in Design ConsiderationsWhen designing this feature, we need to consider the following aspects:
|
@tarekgh @cijothomas FYI |
And the performance overhead of ds listeners/reflection etc. |
Tagging subscribers to this area: @tarekgh, @tommcdon, @pjanotti Issue DetailsCurrent StateCurrently, users depend on the instrumentation library provided by the OpenTelemetry .NET repository to enable the enrichment of activities created during HttpClient requests, following the OpenTelemetry specification. This instrumentation library enriches activities by subscribing to DiagnosticSource events generated by HttpClient. However, this approach has certain limitation. Feature RequestWe are requesting the addition of native instrumentation support for HttpClient in Design ConsiderationsWhen designing this feature, we need to consider the following aspects:
|
Moved this to /cc @noahfalk |
Tagging subscribers to this area: @dotnet/ncl Issue DetailsCurrent StateCurrently, users depend on the instrumentation library provided by the OpenTelemetry .NET repository to enable the enrichment of activities created during HttpClient requests, following the OpenTelemetry specification. This instrumentation library enriches activities by subscribing to DiagnosticSource events generated by HttpClient. However, this approach has certain limitation and performance overhead of Diagnostic Source listeners and reflection. Feature RequestWe are requesting the addition of native instrumentation support for HttpClient in Design ConsiderationsWhen designing this feature, we need to consider the following aspects:
|
Talked offline with @noahfalk and changed it back to http as the work will be in http. |
@vishweshbankwar a question regarding the timing of tag injection and enrichment: opentelemetry-dotnet's HttpHandlerDiagnosticListener sets some of the tags at |
In the current implementation which is based on the diagnostic source callbacks, there was no way to allow enrich via single API (due to different callbacks with different information). If that constraint is not valid for instrumentation within the library, it makes sense to have a simpler API. |
Support for standard tags has been implemented in #104251. We still need to add enrichment, and investigate the API differences for custom propagators. Hopefully this will happen in .NET 10. |
@antonfirsov doesn't sampling take place at the beginning and thus would be able to take those initial tags into account? Or does it happen even before that and thus this would make no difference? |
The initial tags are available for Samplers, so yes they are useful for sampler. I believe the question was - "are there practical examples of samplers that would make use of these additional tags?". Given this is a Client span, which usually has a parent span, the sampling decision typically follows that of the parent's decision. So compared to Asp.Net Core (server spans), initial tags have less use case for HTTP Client. |
@cijothomas I'd imagine this could be quite useful for a custom sampler implementation, where the author may add custom tags via enrichment, and then leverage them in their own sampling logic. Some stuff that immediately comes to my mind here is in a multi-tenant system (like ours) where there we could add the If all enrichment happened at the end only, this would be impossible to achieve. Somewhat related: |
@julealgon You are right. I only meant to highlight that, this is less valuable than getting the initial tags for asp.net core. (for the tenant_id example - won't you want to sample the asp.net server span as well? Changes in httpclient won't help there, right?) |
Ah that makes sense. Agreed.
Not all flows start from AspNetCore in our case, but you are mostly right: usually the httpclient spans will have another parent anyways that we could enrich and check for the tenant. As another example that would better fit the httpclient spans, we have another scenario in our system where some of our vendor-related HTTP calls are based on specific OEMs, which we have an enum for. We could enrich such httpclient spans with the specific OEM ID and then filter based on that later on a sampler. This is another real scenario that we have today and I do intend to allow something like this because our current way of "tracing" those OEM specific calls is completely custom. In this case, even though the parent span would have a specific tenant, for a single tenant, there might be many different such OEM integrations, which we might want to track/debug separately (say, have different sampling percentages based on the OEM to diagnose a specific problem without incurring extra overhead on the observability tool quotas/generating extra expenses for us. |
There was a lot of back-and-forth whether we should do this or not, see discussion under #104251 (comment). In the end, we decided not to do it, for perf reasons. Even if we add support, IMO it should be opt-in. Please open a separate issue if this is important for you, with detailed explanation of the use-case so we can discuss and triage. |
Thanks for the update @antonfirsov . I would rather the team opted to just provide the 2 mechanisms out of the gate than limit it like that. For instance, give the consumer the option to enrich at the beginning or at the end, and make it clear that there is a penalty when doing it in the beginning, at least for now, until the allocation issues can be resolved/mitigated. Hopefully this will be reconsidered in the future. I'll open a request if it comes to a point where we need one of the samplers I mentioned above since we don't have them quite yet and we may be able to get away with a processor to discard the spans like the comment mentioned in the comment thread you linked. |
That needs an API, which complicates things given that the bar is very high in BCL when it comes to defining API-s. Rule of thumb: if we think that there are maybe some users who will use it, we're not gonna do it. If there are users who definitely need it, we will maybe do it -- this depends on the number users knocking on our gates, which can be quantified eg. by the number of upvotes on the issue that asks for a particular knob. |
Current State
Currently, users depend on the instrumentation library provided by the OpenTelemetry .NET repository to enable the enrichment of activities created during HttpClient requests, following the OpenTelemetry specification. This instrumentation library enriches activities by subscribing to DiagnosticSource events generated by HttpClient. However, this approach has certain limitation and performance overhead of Diagnostic Source listeners and reflection.
Feature Request
We are requesting the addition of native instrumentation support for HttpClient in
.NET 9.0
. This enhancement will complement the out-of-the-box OTel metrics instrumentation introduced in.NET 8.0
.Design Considerations
When designing this feature, we need to consider the following aspects:
Support for Enrichment and Filtering of Spans: Ensure that the native instrumentation supports the enrichment and filtering of HttpClient spans.
Custom Propagators: Address the differences in API between propagators in OpenTelemetry and the
DistributedContextPropagator
. Determine how custom propagators should be handled in this context.The text was updated successfully, but these errors were encountered: