Gunicorn + Gevent + Открытая телеметрия

Кто-нибудь использует Django + Gunicorn + Gevent + Opentelemetry в производстве? Хотелось бы узнать, как вы заставили это работать.

Похоже, я не могу использовать BatchSpanProcessor или BatchLogRecordProcessor. Я получаю ошибки, которые, похоже, содержат много открытых проблем, но не нашли решения.

Я получаю это после запуска gunicorn, но сервер по-прежнему принимает запросы и обслуживает их.

Traceback (most recent call last):
  File "src/gevent/_abstract_linkable.py", line 287, in gevent._gevent_c_abstract_linkable.AbstractLinkable._notify_links
  File "src/gevent/_abstract_linkable.py", line 333, in gevent._gevent_c_abstract_linkable.AbstractLinkable._notify_links
AssertionError: (None, <callback at 0xffffb32b0640 args=([],)>)
2025-06-09T14:58:34Z <callback at 0xffffb32b0640 args=([],)> failed with AssertionError

2025-06-09T14:58:34Z <callback at 0xffffb32903c0 args=([],)> failed with AssertionError

Когда я начинаю обращаться к нему с большим количеством запросов, появляется следующая ошибка, которая вызывает проблемы.

2025-06-09T14:40:18Z <Greenlet at 0xffff65bb5b20: <bound method Thread._bootstrap of <Thread(OtelBatchSpanRecordProcessor, stopped daemon 281472388520736)>>> failed with KeyError

Traceback (most recent call last):
  File "src/gevent/greenlet.py", line 900, in gevent._gevent_cgreenlet.Greenlet.run
  File "/usr/local/lib/python3.11/threading.py", line 1002, in _bootstrap
    self._bootstrap_inner()
  File "/usr/local/lib/python3.11/threading.py", line 1037, in _bootstrap_inner
    del _limbo[self]
        ~~~~~~^^^^^^
KeyError: <Thread(OtelBatchSpanRecordProcessor, stopped daemon 281472388522016)>

Я запускаю код otel с wsgi.py при этом значение preload app равно false. Таким образом, код выполняется после разветвления и исправления gevent monkey. Это я подтвердил.

Ниже приведена функция, которую я использую для запуска otel instrumentation

Вернуться на верх