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

Introduce TaskDecorator variant for Context Propagation #31130

Closed
bclozel opened this issue Aug 29, 2023 · 1 comment
Closed

Introduce TaskDecorator variant for Context Propagation #31130

bclozel opened this issue Aug 29, 2023 · 1 comment
Assignees
Labels
in: core Issues in core modules (aop, beans, core, context, expression) theme: observability An issue related to observability and tracing type: enhancement A general enhancement
Milestone

Comments

@bclozel
Copy link
Member

bclozel commented Aug 29, 2023

As discussed in #30089 and #29977, Spring Framework does not intend to instrument @Async or @EventListener methods for Observations. Creating dedicated observations would require:

  • an observation name: "event.processing", "async.execution" could work
  • a metric: measuring the execution time
  • actionable metadata: here, we could collect the name of the method being called and possibly the event type
  • meaningful semantics: that's where things don't fit. An event being processed or a method being executed asynchronously doesn't tell much about the use case; this is really about the "how?" but not the "what?". Some instances are probably worthy of instrumentation, but with a custom observation that says more about the use case, such as "email.notification.processing"

Also, many Spring applications can process a high number of application events. By default, those are designed to be processed quickly and synchronously within the publisher thread. Measuring processing time there will waste CPU cycles and yield very small measurements that are within the error margin.

On the other hand, there are cases where an existing observation is already active. For example, a web application receives a request and publishes an event as a result. If the dispatching of application events is done on a different Thread, the current context (i.e. ThreadLocals) is lost. This means that the observation trace is not propagated and that the logging context (the MDC information) is not present during execution.

Such use cases are covered by the Micrometer Context Propagation library. This issue is about offering an opt-in, flexible way of propagating context for @Async and @EventListener annotated methods. Some applications might want to apply this globally, while others probably want to apply it selectively in order not to introduce unnecessary overhead in the application.

We can introduce here a new TaskDecorator implementation that calls the Context Propagation library. If the application uses an ExecutorService directly, wrapping it with the io.micrometer.context.ContextExecutorService is the best choice.

@bclozel bclozel added in: core Issues in core modules (aop, beans, core, context, expression) type: enhancement A general enhancement theme: observability An issue related to observability and tracing labels Aug 29, 2023
@bclozel bclozel added this to the 6.1.0-RC1 milestone Aug 29, 2023
@bclozel bclozel self-assigned this Aug 29, 2023
@BenetatosG
Copy link

BenetatosG commented Sep 23, 2024

Hello @bclozel,
Can you please provide an example how to preserve the traceId when working with TransactionalEventListener?
I have tried adding a task decorator on the ApplicationEventMulticaster but with no success.

I expect to have same traceId when TransactionalEventListener handles the event but, the MDC context does not have the original traceId, and it does contain just a new traceId

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
in: core Issues in core modules (aop, beans, core, context, expression) theme: observability An issue related to observability and tracing type: enhancement A general enhancement
Projects
None yet
Development

No branches or pull requests

2 participants