-
Notifications
You must be signed in to change notification settings - Fork 515
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
79e3316
commit d65cc68
Showing
1 changed file
with
83 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,19 +4,91 @@ | |
|
||
### Various fixes & improvements | ||
|
||
- Add support for Sentry Crons to Celery Beat (#1935) by @antonpirker | ||
- Add decorator for Sentry tracing (#1089) by @ynouri | ||
- Added top level API to get current span (#1954) by @antonpirker | ||
- feat(profiling): Add profiler options to init (#1947) by @Zylphrex | ||
- Start a real http server instead of mocking libs (#1938) by @antonpirker | ||
- feat(profiling): Set active thread id for quart (#1830) by @Zylphrex | ||
- 🎨 Fix type annotation for ignore_errors in sentry_sdk.init() (#1928) by @tiangolo | ||
- Update get_json function call for werkzeug 2.1.0+ (#1939) by @michielderoos | ||
- fix: Rename MYPY to TYPE_CHECKING (#1934) by @untitaker | ||
- Rename 'with_locals' to 'include_local_variables' (#1924) by @antonpirker | ||
- Returning the tasks result. (#1931) by @antonpirker | ||
- **New:** Monitor Celery Beat tasks with Sentry [Cron Monitoring](https://docs.sentry.io/product/crons/). | ||
|
||
With this feature you can make sure that your Celery beat tasks run at the right time and see if they where successful or not. | ||
|
||
> **Warning** | ||
> Cron Monitoring is currently in beta. Beta features are still in-progress and may have bugs. We recognize the irony. | ||
> If you have any questions or feedback, please email us at [email protected], reach out via Discord (#cronjobs), or open an issue. | ||
Usage: | ||
|
||
```python | ||
# File: tasks.py | ||
|
||
from celery import Celery, signals | ||
from celery.schedules import crontab | ||
|
||
import sentry_sdk | ||
from sentry_sdk.crons import monitor | ||
from sentry_sdk.integrations.celery import CeleryIntegration | ||
|
||
|
||
# 1. Setup your Celery beat configuration | ||
|
||
app = Celery('mytasks', broker='redis://localhost:6379/0') | ||
app.conf.beat_schedule = { | ||
'set-in-beat-schedule': { | ||
'task': 'tasks.tell_the_world', | ||
'schedule': crontab(hour='10', minute='15'), | ||
'args': ("in beat_schedule set", ), | ||
}, | ||
} | ||
|
||
|
||
# 2. Initialize Sentry either in `celeryd_init` or `beat_init` signal. | ||
|
||
#@signals.celeryd_init.connect | ||
@signals.beat_init.connect | ||
def init_sentry(**kwargs): | ||
sentry_sdk.init( | ||
dsn='...', | ||
integrations=[CeleryIntegration()], | ||
environment="local.dev.grace", | ||
release="v1.0.7-a1", | ||
) | ||
|
||
|
||
# 3. Link your Celery task to a Sentry Cron Monitor | ||
|
||
@app.task | ||
@monitor(monitor_slug='3b861d62-ff82-4aa0-9cd6-b2b6403bd0cf') | ||
def tell_the_world(msg): | ||
print(msg) | ||
``` | ||
|
||
- **New:** Add decorator for Sentry tracing (#1089) by @ynouri | ||
|
||
This allows you to use a decorator to setup custom performance instrumentation. | ||
|
||
To learn more see [Custom Instrumentation](https://docs.sentry.io/platforms/python/performance/instrumentation/custom-instrumentation/). | ||
|
||
Usage: Just add the new decorator to your function, and a span will be created for it: | ||
|
||
```python | ||
import sentry_sdk | ||
|
||
@sentry_sdk.trace | ||
def my_complex_function(): | ||
# do stuff | ||
... | ||
``` | ||
|
||
- Make Django signals tracing optional (#1929) by @antonpirker | ||
|
||
See the [Django Guide](https://docs.sentry.io/platforms/python/guides/django) to learn more. | ||
|
||
- Deprecated `with_locals` in favor of `include_local_variables` (#1924) by @antonpirker | ||
- Added top level API to get current span (#1954) by @antonpirker | ||
- Profiling: Add profiler options to init (#1947) by @Zylphrex | ||
- Profiling: Set active thread id for quart (#1830) by @Zylphrex | ||
- Fix: Update `get_json` function call for werkzeug 2.1.0+ (#1939) by @michielderoos | ||
- Fix: Returning the tasks result. (#1931) by @antonpirker | ||
- Fix: Rename MYPY to TYPE_CHECKING (#1934) by @untitaker | ||
- Fix: Fix type annotation for ignore_errors in sentry_sdk.init() (#1928) by @tiangolo | ||
- Tests: Start a real http server instead of mocking libs (#1938) by @antonpirker | ||
|
||
## 1.16.0 | ||
|
||
### Various fixes & improvements | ||
|