Django celery KeyError “Received unregistered task of type报错解决

报错提示 Did you remember to import the module containing this task?
Or maybe you are using relative imports?

下面总结几种可能结果

  1. 消息队列中缓存之前的任务,清理删除消息队列(rabbitmq或redis)看你使用是什么消息队列,重启celery

  2. 任务未被注册
    在celery.py中

app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
  1. 采用导入指定的 task 的方式
CELERY_IMPORTS = (                                    # 指定导入的任务模块
     'celery_app.task1' ,
     'celery_app.task2'
)
  1. 自动命名和相对导入

“相对导入"和"自动名称生成"在一起工作的不是很好,所以如果你使用了"相对导入”,就需要显式地指明名字。

比如,如果客户端导入模块"myapp.tasks"作为".tasks",然后worker导入模块作为“myapp.tasks”,这样自动生成的名字就不能够正确匹配,worker就会抛出一个 NotRegistered异常。
5 自己命名异步任务

@ task ( name = 'proj.tasks.add' )
def add ( x , y ) :
     return x + y

你可能感兴趣的:(Django,celery)