Отладка сельдерея djcelery через pdb - PullRequest
20 голосов
/ 28 декабря 2010

Кто-нибудь пробовал отлаживать celeryd с помощью pdb? Всякий раз, когда встречается точка останова (либо при запуске celeryd через pdb, либо pdb.set_trace()), я получаю следующую ошибку:

Error while handling action event.
Traceback (most recent call last):
  File "/home/jeeyo/workspace3/uwcr/subscriptions/tasks.py", line 79, in process_action_event
    func(action_event)
  File "/home/jeeyo/workspace3/uwcr/subscriptions/tasks.py", line 36, in new_user_email
    send_registration_email(username, new_user.get_profile().plaintext_password)
  File "/home/jeeyo/workspace3/uwcr/looers/email.py", line 18, in send_registration_email
    'Your password from UWCoopRankings', user
  File "/home/jeeyo/workspace3/uwcr/looers/email.py", line 61, in send_email
    if isinstance(to, basestring):
  File "/home/jeeyo/workspace3/uwcr/looers/email.py", line 61, in send_email
    if isinstance(to, basestring):
  File "/usr/lib/python2.6/bdb.py", line 46, in trace_dispatch
    return self.dispatch_line(frame)
  File "/usr/lib/python2.6/bdb.py", line 65, in dispatch_line
    if self.quitting: raise BdbQuit
BdbQuit

Есть какое-нибудь решение для этого?

1 Ответ

17 голосов
/ 05 февраля 2011

У меня была такая же проблема.Попробуйте вместо этого использовать удаленный отладчик Celery rdb:

from celery import task
from celery.contrib import rdb

@task()
def add(x, y):
    result = x + y
    rdb.set_trace()  # <- set break-point
    return result

См. Руководство пользователя (ссылка обновлена ​​2017/5).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...