KEMBAR78
feat(redisotel): add WithCallerEnabled option by boekkooi-impossiblecloud · Pull Request #3415 · redis/go-redis · GitHub
Skip to content

Conversation

@boekkooi-impossiblecloud
Copy link
Contributor

@boekkooi-impossiblecloud boekkooi-impossiblecloud commented Jun 23, 2025

Good day,

While profiling our application we noticed that more time then we expected was spend in funcFileLine called as part of the redisotel tracing. In our scenario we don't actually need the code.function, code.filepath and code.lineno attributes for which funcFileLine is called, so I created this PR.

This PR introduces a new option for redisotel tracing called WithCallerEnabled using it allows one to disable the collection of the code.function, code.filepath and code.lineno tracing attributes. When setting WithCallerEnabled(false) overall performance is increased as the "expensive" runtime.Callers and runtime.(*Frames).Next calls are no longer needed.

Thank you for reviewing this PR and please let me know what you think!
Have a great day!

image

Allow the disabling the collection of the `code.function`, `code.filepath` and `code.lineno` tracing attributes.
When setting `WithCaller(false)` overall performance is increased as the "expensive" `runtime.Callers` and `runtime.(*Frames).Next` calls are no longer needed.
Copy link
Member

@ndyakov ndyakov left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for your contribution. Left a single comment regarding naming. Overall looks good to me. By the way, if you are an active user of redisotel we are looking for community members to maintain it.

@boekkooi-impossiblecloud
Copy link
Contributor Author

boekkooi-impossiblecloud commented Jun 23, 2025

Hey @ndyakov,

Thank you for the very quick review! The company I work for uses redisotel but more in a way that it works and forget about it.
What would it entail to help maintain redisotel?

@boekkooi-impossiblecloud boekkooi-impossiblecloud changed the title feat(redisotel): add WithCaller option feat(redisotel): add WithCallerEnabled option Jun 23, 2025
@ndyakov
Copy link
Member

ndyakov commented Jun 23, 2025

@boekkooi-impossiblecloud Mainly PR reviews and if there are opened issues related to redisotel - checking them, answering questions and from time to time fixing bugs. At this time, we don't have a specific roadmap for redisotel as long as it is compatible with the go-redis releases. Features like this PR are welcomed.

Copy link
Member

@ndyakov ndyakov left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The PR looks good to me. Willing to merge and include in the next release. Won't change the default behaviour, extends the api => labeled as a feature.

@ndyakov ndyakov merged commit fa475cb into redis:master Jun 24, 2025
16 checks passed
@boekkooi-impossiblecloud
Copy link
Contributor Author

Hey @ndyakov
Thanks a lot for the quick review and merge.

Regarding maintaining/supporting the redisotel package. On Fridays I have time to work on opensource projects and I would be glad to support the package and improve it when needed.
Let's me know if the offer is still open and how we can move forward.

@ndyakov
Copy link
Member

ndyakov commented Jun 25, 2025

Hey @boekkooi-impossiblecloud, of course. Feel free to join https://discord.gg/8eQ93A8Y and I can provide you with more information.

ofekshenawa pushed a commit to ofekshenawa/go-redis that referenced this pull request Jun 30, 2025
* feat(redisotel): add WithCaller option

Allow the disabling the collection of the `code.function`, `code.filepath` and `code.lineno` tracing attributes.
When setting `WithCaller(false)` overall performance is increased as the "expensive" `runtime.Callers` and `runtime.(*Frames).Next` calls are no longer needed.

* chore(redisotel): improve docblock language

* chore(redisotel): rename `WithCaller` to `WithCallerEnabled`

---------

Co-authored-by: Nedyalko Dyakov <1547186+ndyakov@users.noreply.github.com>
ofekshenawa pushed a commit that referenced this pull request Aug 10, 2025
* feat(redisotel): add WithCaller option

Allow the disabling the collection of the `code.function`, `code.filepath` and `code.lineno` tracing attributes.
When setting `WithCaller(false)` overall performance is increased as the "expensive" `runtime.Callers` and `runtime.(*Frames).Next` calls are no longer needed.

* chore(redisotel): improve docblock language

* chore(redisotel): rename `WithCaller` to `WithCallerEnabled`

---------

Co-authored-by: Nedyalko Dyakov <1547186+ndyakov@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants