我正在使用Django 1.10
+ celery==4.0.0rc3
+ django-celery with commit @79d9689b62db3d54ebd0346e00287f91785f6355
。
我的设置是:
CELERY_RESULT_BACKEND = 'djcelery.backends.database:DatabaseBackend'
CELERY_ACCEPT_CONTENT = ['json']
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TIMEZONE = TIME_ZONE
# http://docs.celeryproject.org/en/latest/getting-started/brokers/redis.html#visibility-timeout
BROKER_TRANSPORT_OPTIONS = {'visibility_timeout': 259200} # 3 days
我的tasks.py我有
@task(queue='assign_rnal_id')
def assign_rnal_id_to_mongo(rnal_id, mongo_id):
print ("something")
return False
在我的django模型中,我重写了save方法,将任务发送给celery:
def save(self, *args, **kwargs):
super(Suggested, self).save(*args, **kwargs)
assign_rnal_id_to_mongo.delay(rnal_id=self.id, mongo_id=self.raw_data['_id'])
当我保存模型对象时,我得到No module named 'celery.datastructures'
任何想法?我有类似的代码适用于旧版本的django和芹菜,做了一些改变吗?
由于
答案 0 :(得分:2)
使用django 1.10和Celery 4.0.x我需要
pip install django-celery-results
pip install django-celery-beat
这解决了我的问题而不需要降级我的芹菜。
答案 1 :(得分:0)
我能在这里找到答案https://github.com/celery/celery/issues/3303#issuecomment-246780116
基本上Django-celery does not support 4.0 yet
所以我降级为celery==3.1.23
,现在可以使用了