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

Would be helpful to have function decorators for transactions and spans #760

Closed
markstory opened this issue Jul 13, 2020 · 7 comments
Closed
Labels
Feature: Performance Hacktoberfest 🎃 Issues eligible for Hacktoberfest!

Comments

@markstory
Copy link
Member

The current context managers for starting transactions and marking spans are great. However, there have been a few cases where having decorators for transactions and spans would make code simpler to understand. For example celery tasks could be written like

@celery.task
@sentry_sdk.transaction(transaction="celery.update.user" op="job")
def update_user(user_id):
    # Do things

Has less visual noise than the decorator does, and when adding/removing instrumentation the entire function doesn't change. The same idea applies to spans:

@sentry_sdk.span(description="github.fetch_users", op="github.api")
def fetch_github_users(...):
    # do the api request and data transformations.

The names of the decorators in this issue are likely rubbish, but I think supporting decorators will help make adding instrumentation simpler for end users as it generates less noisy differences and reduces the amount of indentation in their code.

@untitaker
Copy link
Member

untitaker commented Jul 13, 2020 via email

@ynouri
Copy link
Contributor

ynouri commented Apr 15, 2021

My team is currently adopting Sentry for our Python code base and have been feeling the need for a decorator too. The main goal is to make it easier to start tracing any arbitrary function, and make the business logic more readable by removing instrumentation code.

We came up with the decorator implementation attached in draft PR #1089.

Does this match with what you had in mind by any chance?

PS: I'm new to Sentry and to the sentry-python code base, apologies in advance if this proposal misses obvious features or edge cases!

@ynouri
Copy link
Contributor

ynouri commented Apr 15, 2021

Also curious if there are any existing alternatives or workarounds for this - we didn't mean to re-invent the wheel.

@ynouri
Copy link
Contributor

ynouri commented Jul 11, 2021

We have been using those decorators in production on a Python 3.8 FastAPI app for a few months now and they seem to get the job done.

I would be willing to push the PR to the finish line (linting, unit tests) but would prefer to get feedback first. @untitaker any thoughts?

@brettc
Copy link

brettc commented Sep 17, 2021

I'm starting to add some custom spans to our FastAPI app, and my immediate thought was: "where are the decorators for this?" What is the status of the PR #1089 ? (and thanks @ynouri, I'll cut and paste your code for now).

@antonpirker antonpirker added the Hacktoberfest 🎃 Issues eligible for Hacktoberfest! label Sep 30, 2022
@sl0thentr0py sl0thentr0py added this to the Performance API improvements milestone Feb 13, 2023
@alecgerona
Copy link

Hey all, since this is merged, any chance we can update the docs as well to show how to use these decorators?

@antonpirker
Copy link
Member

Hey @alecgerona

Have a look at this documentation: https://docs.sentry.io/platforms/python/performance/instrumentation/custom-instrumentation/

There is described how to use the decorators to create spans. (We do not have a decorator to create transactions)
I guess we can close this issue now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Feature: Performance Hacktoberfest 🎃 Issues eligible for Hacktoberfest!
Projects
None yet
Development

No branches or pull requests

7 participants