首页 > 解决方案 > 芹菜不运行任务

问题描述

请帮助我,了解我做错了什么。芹菜不运行我的任务。

Settings.py
CELERY_BROKER_URL = 'redis://localhost:6379'
CELERY_RESULT_BACKEND = 'redis://localhost:6379'
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TIMEZONE = TIME_ZONE

项目/芹菜.py

from __future__ import absolute_import
import os
from celery import Celery
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'proj.settings') 

app = Celery('proj')
app.config_from_object('django.conf:settings', namespace='CELERY')
app.autodiscover_tasks()

初始化.py

from __future__ import absolute_import, unicode_literals
from celery import app as celery_app   
__all__ = ['celery_app']

代码

@shared_task
def generate(instance, sender, **kwargs):
    for i in CK_PROGRAM_NAME:
        program_kf = i[0]
        ck = instance.dk*program_kf
        program_name = i[1]
        program_obj = Program.objects.get(name=program_name)
        foodprogram_generator(instance, ck, program_kf, program_obj, sender, **kwargs)
    return

@receiver(post_save, sender=LeadUser)
def leaduser_foodprogram_post_save(instance, sender, **kwargs):
    generate.delay(instance, sender, **kwargs)
    return

Worker 由 celery -A proj worker --loglevel=INFO 运行

逻辑是:在client_object创建后,post_save信号启动leaduser_foodprogram_post_save,添加到队列generate()

我可以看到结果,所以我认为它没有运行。没有芹菜一切正常。

谢谢你的回答!

标签: djangorediscelery

解决方案


有几件事:: * 带有命名空间的 config_from_object 可能会从变量中删除它,所以你可能无法得到你想要的配置,* 当你看到共享任务时,你需要确保你是从配置的 celery 调用任务app,因为使用共享任务的主要目的是在不同的应用程序之间实际共享任务。看看 celery 应用程序对象上的“set_default”函数,只需在 celery 设置上调用它,您应该会看到不同之处。无论如何,最好的检查方法是将 rdb 放在那里并检查 celery 应用程序,检查配置,如果没有设置代理,那么我之前评论中解释的第二点应该让你继续


推荐阅读