将 Sentry.io 与 QuartTrio 一起使用 - 有人可以使用它吗?

问题描述 投票:0回答:1

有人能够让 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
    +------------------------------------

我不太确定这里发生了什么,甚至不确定从哪里开始调试它?任何帮助将不胜感激。

python sentry quart
1个回答
0
投票

https://github.com/getsentry/sentry-python/issues/3036

我在这里为 Sentry 的 python 团队创建了一个问题,这将是获得支持的最快方法:)

© www.soinside.com 2019 - 2024. All rights reserved.