2016-09-20 24 views
0

我正在使用Django 1.10 + celery==4.0.0rc3 + django-celery with commit @79d9689b62db3d54ebd0346e00287f91785f6355芹菜 - 沒有名爲'celery.datastructures'的模塊

我的設置是:

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模型我正在重寫保存方法將任務發送到芹菜:

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和芹菜工作,做了一些改變?

感謝

回答

1

使用Django 1.10和芹菜4.0.x的,我需要

pip install django-celery-results 
pip install django-celery-beat 

這解決了我的問題,無需降級我的芹菜。

+0

現在應該是正確的答案。 – psychok7

+0

您是否知道是否有方法監控這些軟件包的Worker狀態? – psychok7

0

我能在這裏找到答案https://github.com/celery/celery/issues/3303#issuecomment-246780116

基本上Django-celery does not support 4.0 yet,所以我降級到celery==3.1.23,現在可

+2

是的! Django-celery已被替換爲4.0的兩個新庫:django-celery-results和django-celery-beat。我們可能會在發佈之前讓django-芹菜工作,這樣它就可以工作,但是當django-芹菜是必要的時候有很多混淆,現在答案是從來沒有。 – asksol

相關問題