Sentry integration for ASGI frameworks.
Project description
sentry-asgi
Sentry integration for ASGI frameworks.
Installation:
pip install sentry-asgi
Usage:
from sentry_asgi import SentryMiddleware
import sentry_sdk
sentry_sdk.init(dsn=...)
app = ...
app = SentryMiddleware(app)
Here's a more complete example, using Starlette:
import sentry_sdk
from sentry_asgi import SentryMiddleware
from sentry_asgi.executor import ContextPreservingExecutor # Python 3.7+
sentry_sdk.init(dsn=...)
app = Starlette()
@app.route("/")
def homepage(request):
raise ValueError("nope")
@app.on_event("startup")
async def setup_executor():
executor = ContextPreservingExecutor()
loop = asyncio.get_event_loop()
loop.set_default_executor(executor)
app.add_middleware(SentryMiddleware)
Notes
Python version support
The Sentry SDK requires Python 3.7's contextvars
support in order to properly
tie messages and logging back to the request context that is added SentryMiddleware.
On 3.6 and below the SentryMiddleware will capture and log application exceptions just fine, but will not properly tie in logging, messages, or breadcrumbs for any code that runs within a threadpool executor or subtask.
ASGI frameworks should ensure that any thread pool executors preserve the contextvar
context.
Endpoint information
It is recommended that frameworks populate an "endpoint" key in the ASGI scope, to indicate which view function or class should be logged by the middleware.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.