有人能够让 Sentry.io 与 QuartTrio 一起使用吗?我制作了最简单的应用程序,从示例代码中复制而来(https://quart-trio.readthedocs.io/en/latest/tutorials/deployment.html):
from quart_trio import QuartTrio
app = QuartTrio(__name__)
@app.route('/')
async def hello():
return 'Hello World'
然后我用
hypercorn -k trio quarttriosentry:app
运行它,一切都按预期工作。
但是一旦我添加了哨兵 SDK,我就崩溃了:
pip install --upgrade sentry-sdk
from quart_trio import QuartTrio
import sentry_sdk
sentry_sdk.init(
dsn="https://<removed>@<removed>.ingest.de.sentry.io/<removed>",
# Enable performance monitoring
enable_tracing=True,
)
app = QuartTrio(__name__)
@app.route('/')
async def hello():
return 'Hello World'
我现在崩溃了:
> hypercorn -k trio quarttriosentry:app
Process SpawnProcess-1:
+ Exception Group Traceback (most recent call last):
| File "/usr/lib/python3.10/multiprocessing/process.py", line 314, in _bootstrap
| self.run()
| File "/usr/lib/python3.10/multiprocessing/process.py", line 108, in run
| self._target(*self._args, **self._kwargs)
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/hypercorn/trio/run.py", line 127, in trio_worker
| trio.run(partial(worker_serve, app, config, sockets=sockets, shutdown_trigger=shutdown_trigger))
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/trio/_core/_run.py", line 2288, in run
| raise runner.main_task_outcome.error
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/hypercorn/trio/run.py", line 46, in worker_serve
| async with trio.open_nursery() as lifespan_nursery:
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/trio/_core/_run.py", line 954, in __aexit__
| raise combined_error_from_nursery
| exceptiongroup.ExceptionGroup: Exceptions from Trio nursery (1 sub-exception)
+-+---------------- 1 ----------------
| Traceback (most recent call last):
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/hypercorn/trio/run.py", line 48, in worker_serve
| await lifespan.wait_for_startup()
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/hypercorn/trio/lifespan.py", line 66, in wait_for_startup
| await self.app_send_channel.send({"type": "lifespan.startup"})
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/trio/_channel.py", line 194, in send
| self.send_nowait(value)
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/trio/_core/_ki.py", line 181, in wrapper
| return fn(*args, **kwargs)
| File "/home/jtuckey/.pyenv/versions/quarttriosentry/lib/python3.10/site-packages/trio/_channel.py", line 172, in send_nowait
| raise trio.ClosedResourceError
| trio.ClosedResourceError
+------------------------------------
我不太确定这里发生了什么,甚至不确定从哪里开始调试它?任何帮助将不胜感激。
https://github.com/getsentry/sentry-python/issues/3036
我在这里为 Sentry 的 python 团队创建了一个问题,这将是获得支持的最快方法:)