芹菜 - 没有名为' celery.datastructures'

时间:2016-09-20 11:01:39

标签: python django celery django-celery

我正在使用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和芹菜,做了一些改变吗?

由于

2 个答案:

答案 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,现在可以使用了