A RetroSearch Logo

Home - News ( United States | United Kingdom | Italy | Germany ) - Football scores

Search Query:

Showing content from https://docs.sentry.io/platforms/python/integrations/celery/ below:

Celery | Sentry for Python

Celery Learn about using Sentry with Celery.

The Celery integration adds support for the Celery Task Queue System .

Install

Install sentry-sdk from PyPI with the celery extra:

Copied

pip install "sentry-sdk[celery]"
Configure

If you have the celery package in your dependencies, the Celery integration will be enabled automatically when you initialize the Sentry SDK.

Make sure that the call to sentry_sdk.init() is loaded on worker startup and not only in the module where your tasks are defined. Otherwise, the initialization may happen too late and events might not get reported.

Set up Celery Without Django

When using Celery without Django, you'll need to initialize the Sentry SDK in both your application and the Celery worker processes spawned by the Celery daemon.

In addition to capturing errors, you can use Sentry for distributed tracing and profiling. Select what you'd like to install to get the corresponding installation and configuration instructions below.

Set up Sentry in Celery Daemon or Worker Processes

Error Monitoring Tracing Profiling

tasks.py

Copied

from celery import Celery, signals
import sentry_sdk


app = Celery("tasks", broker="...")


@signals.celeryd_init.connect
def init_sentry(**_kwargs):
    sentry_sdk.init(
        dsn="https://examplePublicKey@o0.ingest.sentry.io/0",
        
        
        send_default_pii=True,
        
        
        
        traces_sample_rate=1.0,
        
        
        
        
        profile_session_sample_rate=1.0,
        
        
        profile_lifecycle="trace",
        
    )


@app.task
def add(x, y):
    return x + y

The celeryd_init signal is triggered when the Celery daemon starts, before the worker processes are spawned. If you need to initialize Sentry for each individual worker process, use the worker_init signal instead.

Set up Sentry in Your Application

Error Monitoring Tracing Profiling

main.py

Copied

from tasks import add
import sentry_sdk

def main():
    
    sentry_sdk.init(
        dsn="https://examplePublicKey@o0.ingest.sentry.io/0",
        
        
        send_default_pii=True,
        
        
        
        traces_sample_rate=1.0,
        
        
        
        
        profile_session_sample_rate=1.0,
        
        
        profile_lifecycle="trace",
        
    )

    
    with sentry_sdk.start_transaction(name="calling-a-celery-task"):
        result = add.delay(4, 4)

if __name__ == "__main__":
    main()
Set up Celery With Django

If you're using Celery with Django in a typical setup, have initialized the SDK in your settings.py file (as described in the Django integration documentation), and have your Celery configured to use the same settings as config_from_object , there's no need to initialize the Celery SDK separately.

Verify

To confirm that your SDK is initialized on worker start, pass debug=True to sentry_sdk.init(). This will add extra output to your Celery logs when the SDK is initialized. If you see the output during worker startup, and not just after a task has started, then it's working correctly.

The snippet below includes an intentional ZeroDivisionError in the Celery task that will be captured by Sentry. To trigger the error call debug_sentry.delay():

tasks.py

Copied

from celery import Celery, signals
import sentry_sdk

app = Celery("tasks", broker="...")

@signals.celeryd_init.connect
def init_sentry(**_kwargs):
    sentry_sdk.init(...)  

@app.task
def debug_sentry():
    1/0

Sentry uses custom message headers for distributed tracing. For Celery versions 4.x, with message protocol of version 1 , this functionality is broken, and Celery fails to propagate custom headers to the worker. Protocol version 2, which is the default since Celery version 4.0, is not affected.

The fix for the custom headers propagation issue was introduced to Celery project (PR ) starting with version 5.0.1. However, the fix was not backported to versions 4.x.

Options

To set options on CeleryIntegration to change its behavior, add it explicitly to your sentry_sdk.init():

Copied

import sentry_sdk
from sentry_sdk.integrations.celery import CeleryIntegration

sentry_sdk.init(
    
    integrations=[
        CeleryIntegration(
            monitor_beat_tasks=True,
            exclude_beat_tasks=[
                "unimportant-task",
                "payment-check-.*"
            ],
        ),
    ],
)

You can pass the following keyword arguments to CeleryIntegration():

Distributed Traces

Distributed tracing extends the trace from the code that's running your Celery task so that it includes the code that initiated the task.

You can disable this globally with the propagate_traces parameter, documented above. If you set propagate_traces to False, all Celery tasks will start their own trace.

If you want to have more fine-grained control over trace distribution, you can override the propagate_traces option by passing the sentry-propagate-traces header when starting the Celery task:

Note: The CeleryIntegration does not utilize the traces_sample_rate config option for deciding if a trace should be propagated into a Celery task.

Copied

import sentry_sdk


sentry_sdk.init(
    
    integrations=[
        CeleryIntegration(
            propagate_traces=True
        ),
    ],
)


my_task_a.delay("some parameter")


my_task_b.apply_async(
    args=("some_parameter", )
)


my_task_b.apply_async(
    args=("some_parameter", ),
    headers={"sentry-propagate-traces": False},
)


Supported Versions

The versions above apply for the current major version of the Python SDK. If you're looking to use Sentry with older Python or framework versions, consider using an older major version of the SDK.

Help improve this content
Our documentation is open source and available on GitHub. Your contributions are welcome, whether fixing a typo (drat!) or suggesting an update ("yeah, this would be better").

RetroSearch is an open source project built by @garambo | Open a GitHub Issue

Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo

HTML: 3.2 | Encoding: UTF-8 | Version: 0.7.4