Skip to content
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

Implement ExtendedTextMapGetter in instrumentations #12868

Open
jamesmoessis opened this issue Dec 10, 2024 · 8 comments
Open

Implement ExtendedTextMapGetter in instrumentations #12868

jamesmoessis opened this issue Dec 10, 2024 · 8 comments
Assignees
Labels
contribution welcome Request makes sense, maintainers probably won't have time, contribution would be welcome enhancement New feature or request

Comments

@jamesmoessis
Copy link
Contributor

jamesmoessis commented Dec 10, 2024

Is your feature request related to a problem? Please describe.

Spec has recently changed to specify extraction of multiple values for a given key: open-telemetry/opentelemetry-specification#4295

The Java SDK has added ExtendedTextMapGetter to handle this: open-telemetry/opentelemetry-java#6852 (when stabilised this extension may become a default method on TextMapGetter which should be then implemented by instrumentations).

Describe the solution you'd like

For instrumentations that have carriers that support multiple values for a single key (most HTTP implementations) this should be a relatively straightforward change.

It does not necessarily need to be supported by all instrumentations.

@jamesmoessis jamesmoessis added enhancement New feature or request needs triage New issue that requires triage labels Dec 10, 2024
@trask trask added contribution welcome Request makes sense, maintainers probably won't have time, contribution would be welcome and removed needs triage New issue that requires triage labels Dec 10, 2024
@xiepuhuan
Copy link
Contributor

xiepuhuan commented Dec 23, 2024

I have gone through all the instrumentations and found that the following 15 TextMapGetter need to be modified. Can I make all the changes to TextMapGetter in single PR?
@trask

  • io.opentelemetry.instrumentation.grpc.v1_6.GrpcRequestGetterImplementing ExtendedTextMapGetter in grpc-1.6 instrumentation #13011
  • io.opentelemetry.javaagent.instrumentation.grizzly.HttpRequestHeadersGetter
  • io.opentelemetry.instrumentation.spring.webmvc.v6_0.JakartaHttpServletRequestGetter
  • io.opentelemetry.instrumentation.spring.webmvc.v5_3.JavaxHttpServletRequestGetterAdd baggage test to AbstractHttpServerTest #13027
  • io.opentelemetry.javaagent.instrumentation.jetty.v12_0.Jetty12TextMapGetter
  • io.opentelemetry.instrumentation.kafka.internal.KafkaConsumerRecordGetter
  • io.opentelemetry.javaagent.instrumentation.liberty.dispatcher.LibertyDispatcherRequestGetter
  • io.opentelemetry.instrumentation.awssdk.v2_2.internal.SqsParentContext.MessageAttributeValueMapGetter
  • io.opentelemetry.javaagent.instrumentation.netty.v3_8.server.NettyHeadersGetter
  • io.opentelemetry.instrumentation.ratpack.v1_7.internal.RatpackGetter
  • io.opentelemetry.instrumentation.restlet.v1_1.internal.RestletHeadersGetter
  • io.opentelemetry.instrumentation.restlet.v2_0.internal.RestletHeadersGetter
  • io.opentelemetry.javaagent.instrumentation.servlet.ServletRequestGetter
  • io.opentelemetry.javaagent.instrumentation.undertow.UndertowExchangeGetter
  • io.opentelemetry.instrumentation.spring.webflux.v5_3.WebfluxTextMapGetter

@xiepuhuan
Copy link
Contributor

Would this contribution be welcome?
@trask

@trask
Copy link
Member

trask commented Jan 6, 2025

hi @xiepuhuan! yes, let's start with just one (pick any), so we can work through any issues/concerns, and then you could do the rest in a single follow-up PR if you'd like to continue

@xiepuhuan
Copy link
Contributor

hi @xiepuhuan! yes, let's start with just one (pick any), so we can work through any issues/concerns, and then you could do the rest in a single follow-up PR if you'd like to continue

Thank you for your reply. I will try to complete the first pull request for ExtendedTextMapGetter.

@xiepuhuan
Copy link
Contributor

#13027 has been merged into the main branch. Next, I want to implement ExtendedTextMapGetter in all http server related instrumentations.
@trask

@trask
Copy link
Member

trask commented Jan 15, 2025

@xiepuhuan sounds great!

@laurit
Copy link
Contributor

laurit commented Jan 16, 2025

#13027 has been merged into the main branch. Next, I want to implement ExtendedTextMapGetter in all http server related instrumentations.

Hope you didn't start with it as I also implemented these in #13053

@xiepuhuan
Copy link
Contributor

#13027 has been merged into the main branch. Next, I want to implement ExtendedTextMapGetter in all http server related instrumentations.

Hope you didn't start with it as I also implemented these in #13053

Although I have achieved some, I believe your implementation will be better. I plan to implement ExtendedTextMapGetter in the instrumentations of non http servers.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
contribution welcome Request makes sense, maintainers probably won't have time, contribution would be welcome enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

4 participants