-
Notifications
You must be signed in to change notification settings - Fork 40.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
Provide a configuration property to specify the order of the ServerHttpObservationFilter #35067
Comments
Any filters with highest precedence should run before
There's no property-based support for this at the moment. Without that support you'd have to define your own |
Issue I have is ServerHttpObservationFilter is ordered as Ordered.HIGHEST_PRECEDENCE + 1 and I have three other filters. This gives me the only option to use Ordered.HIGHEST_PRECEDENCE which will randomly be ordered. :-( I can define my own ServerHttpObservationFilter no problem but a property would be cleaner. Thanks |
The property is named |
We need to consider the servlet side of things as well. The property should either be applied to the auto-configured |
Thanks Andy, i missed that. |
I've just learned about spring-projects/spring-framework@96a429a. We need to review these changes in the context of that deprecation and what it means for the requirement raised here. /cc @bclozel |
We need to set the |
How would that work for the original requirement where "we have some filters which we need to run before any observation"? |
Sorry for the late feedback. The Servlet Filter abstraction works well in general for Spring MVC, although some people find that limited and prefer a custom Tomcat Valve for observations in order to observe the entire chain, servlet container error processing included. To be accurate, the observation filter should be as early as possible in order to measure most of the processing time. I don't think we have similar properties for other filters in Spring Boot and the general feedback so far was to configure your own filter instance. I'm not against this change, but I guess this would mean that we implement the same thing for other filters. On the WebFlux side, the With the new infrastructure, the observation starts before any webfilter is involved. @davidmelia can you share more about the use case? Maybe there is something we can do to help with that without relying on extra filters? With that in mind, if we want to provide configuration properties for servlet filters, we probably need a |
I'm afraid it doesn't, like Brian said. It only gets rid of the deprecation. The changes to get rid of the deprecation are in this branch. However, there are 3 tests in |
I think we should revert the changes that have been made thus far for this issue. The requirement hasn't been raised for servlet apps and, until we hear from @davidmelia, we don't know what, if anything, we might need to do for reactive apps. |
Hi @bclozel @wilkinsona - in terms of my use case we have a few custom filters which need to happen to set up the observation context - this includes extracting the IP address from a custom header and extracting other sources of data. All of this data is integral to our logging context information (N.B I have a custom logging.pattern.level) Therefore, while I understand the assumption that Thanks N.B My only use case is reactive. |
I reverted the commits in the meantime. |
@davidmelia I'm not really sure I understand the use case here. If you are trying to have additional metrics/traces tags contributed to the observation, you don't need to set things up before the observation starts. Writing your own If your goal is to customize the context propagation, I would need more information. Maybe you are trying to get ahead of the web observation to pre-populate the MDC with custom values? In this case, I believe you can achieve this by contributing a |
@bclozel I have tried HttpHandlerDecoratorFactory and it works great :-) . This actually removes my need to override this filter order. |
That's excellent news. Thanks for letting us know, @davidmelia. I'm going to close this one as we no longer have a need to make the filter order configurable, for either web stack. |
@davidmelia it would be great if you could share your solution involving HttpHandlerDecoratorFactory to shed some light for others. I have a similar use case: extracting a special header value from the the request (using a very high order once per request filter - request has to be rejected in case of an invalid value) where the value is vital for the rest of the lifecycle. I have been setting the value in MDC there to make it available in logs, and also wanted to make it globally available for all metrics. I read the thread and learned that very high precedence is intentional here. what would you recommend for this use case? How HttpHandlerDecoratorFactory helped? |
@edigu your use case might be a bit different actually.
Maybe you can share those details in a StackOverflow question and point us to it? A closed issue isn't the right place to get help on a different matter. |
Yes you are right, will try SO in worst case. Wanted to get feedback since the use case is quite similar. |
@edigu my use-case is to set up the log context which i used to do using web filters without realising I could simply use HttpHandlerDecoratorFactory. Below is an example. I can have multiple factories for the different log context concerns
|
I have similar usecase (but for Servlet code, actually I don't get why the distinction, both cases might need the same) - described in https://stackoverflow.com/questions/79062775/adding-keyvalues-from-custom-filters-to-observationconvention Basically I need a way to inject values into observation later in the lifecycle, after another filter has been executed (it injects values that I need to observer). I would also be able to get this data from Spring Security (which works in together with the custom filter), but again, I'm not sure how I could that. This is to allow a metric where I could see which kind of user groups (taken from either filter or spring security) use given URIs. |
@krzyk I have asked clarifying questions on your SO post. |
@krzyk it seems the SO link is broken. |
Hi,
Migrating from Spring Cloud Sleuth to Spring Boot 3 there used to be a property to override the TraceFilter:
which is quite important for us as we have some filters which we need to run before any observation. I have noticed in Spring Boot 3 the order is hardcoded:
Is it possible to override
ServerHttpObservationFilter
order (specifically the reactive version)?Thanks
The text was updated successfully, but these errors were encountered: