我的 Celery 任务在我的 Django 1.7/Python3 项目中没有在后台执行。
# settings.py
BROKER_URL = 'redis://localhost:6379/0'
CELERY_RESULTBACKEND = BROKER_URL
CELERYBEAT_SCHEDULER = 'djcelery.schedulers.DatabaseScheduler'
CELERY_ALWAYS_EAGER = False
我在根应用程序模块中具有这样的celery.py
:
from __future__ import absolute_import
import os
import django
from celery import Celery
from django.conf import settings
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'my_app.settings')
django.setup()
app = Celery('my_app')
app.config_from_object('django.conf:settings')
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
并在根模块中加载__init__.py
中的应用程序:
from __future__ import absolute_import
from .celery import app as celery_app
我的任务在我的应用模块的 tasks.py 文件中设置为共享任务:
from __future__ import absolute_import
from celery import shared_task
@shared_task
def update_statistics(profile, category):
# more code
我将任务称为一个组:
. . .
job = group([update_statistics(f.profile, category)
for f in forecasts])
job.apply_async()
但是,我在任务队列中没有看到任何状态更新,我通过以下方式启动该队列:
$ celery -A my_app worker -l info
任务正在执行,只是不在后台执行。如果我在任务代码中添加一个 print 语句,我将在我的 Django 开发服务器控制台而不是 Celery 队列中看到输出。
任务在前台运行后,我会看到以下异常:
'NoneType' object has no attribute 'app'
如果您有兴趣,以下是完整的回溯: https://gist.github.com/alsoicode/0263d251e3744227ba46
创建组时,您将直接在列表理解中调用任务,因此它们随后会在那里执行。您需要使用 .subtask()
方法(或其快捷方式,.s()
)来创建子任务而不调用它们:
job = group([update_statistics.s(f.profile, category) for f in forecasts])