ariadne
ariadne copied to clipboard
Make it possible to exempt some resolvers from tracing
The default behavior of only tracing custom resolvers is great 95% of the time, however there is a case for not to trace certain custom resolvers as well.
We have a few simple custom resolvers that can be called up to a couple thousand times per request where the tracing overhead becomes significant. Also, in our case they don't do meaningful work that would warrant tracing them.
Right now I see two ways to implement a workaround in our code-base without touching ariadne itself:
- Monkey-patch
ariadne.contrib.tracing.should_tracefunction - Add
_ariadne_alias_resolverattribute to our own resolvers, disguising them as alias resolvers which are already exempt fro tracing. - Extend the tracing extensions in our code to do the filtering.
The first two approaches are brittle and can break upon any update to ariadne. We can go forward using the third approach but we think it'd make sense to add this functionality in ariadne itself.
I'd like to contribute support for this functionality in ariadne if you accept my reasoning for the need of it. My plan is to add a filter callable to the tracing extensions that can look-up the field in a block-list or perform any other custom logic.
An even less intrusive change could also be just adding a should_trace method in the tracing extensions that can be overridden in a subclass, instead of using a non-member function.
Construction option (like we are already doing with args_filter) is the way to go here IMHO. This option should default to should_trace.
I've taken a quick look and it is easy to do this way but the should_trace function having a trace_default_resolver bool argument makes it a bit smelly to me. One part of the tracing is configured via a callable, the other via a separate flag seems weird. It is easy to make should_trace be more restrictive via wrapping it to a separate function but it is hard to make it more permissive without duplicating its contents.
Yeah, we should drop trace_default_resolver at same time, but it would be good to have both at same time for deprecation period.
For now we could have both options but raise an error if custom tracing filter is set together with trace_default_resolver.
Actually, I've found a way to implement extensions that is much faster that what we currently have, and I would like to implement it in future release of Ariadne, but I've been busy with other commitments recently that prevented me from doing so.
Faster extensions landed in Ariadne 0.20, but as I've mentioned on Ariadne's blog, there's still utility in having an option to remove fields from tracing extensions for removing the especially noisy resolvers from APM.