报错提示 Did you remember to import the module containing this task?
Or maybe you are using relative imports?
下面总结几种可能结果
-
消息队列中缓存之前的任务,清理删除消息队列(rabbitmq或redis)看你使用是什么消息队列,重启celery
-
任务未被注册
在celery.py中
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
- 采用导入指定的 task 的方式
CELERY_IMPORTS = ( # 指定导入的任务模块
'celery_app.task1' ,
'celery_app.task2'
)
- 自动命名和相对导入
“相对导入"和"自动名称生成"在一起工作的不是很好,所以如果你使用了"相对导入”,就需要显式地指明名字。
比如,如果客户端导入模块"myapp.tasks"作为".tasks",然后worker导入模块作为“myapp.tasks”,这样自动生成的名字就不能够正确匹配,worker就会抛出一个 NotRegistered异常。
5 自己命名异步任务
@ task ( name = 'proj.tasks.add' )
def add ( x , y ) :
return x + y