我的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
我的任务在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
答案 0 :(得分:5)
您在创建组时直接在列表推导中调用任务,因此它们会在那时执行。您需要使用.subtask()
方法(或其快捷方式.s()
)来创建子任务而不调用它们:
job = group([update_statistics.s(f.profile, category) for f in forecasts])