我在这里看过这个例子:
http://docs.celeryproject.org/en/latest/django/first-steps-with-django.html
我的所有任务都在名为tasks.py。
的文件中更新芹菜并从示例中添加文件django抛出以下错误,无论我尝试什么:
ImportError: cannot import name Celery
问题是否可能由以下原因引起?
app.autodiscover_tasks(settings.INSTALLED_APPS, related_name='tasks')
因为它遍历所有具有以下导入的tasks.py文件。
from cloud.celery import app
云/ celery.py :
from __future__ import absolute_import
import os, sys
from celery import Celery
from celery.schedules import crontab
from django.conf import settings
BROKER_URL = 'redis://:PASSWORD@localhost'
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'cloud.settings')
app = Celery('cloud', broker=BROKER_URL)
app.config_from_object('django.conf:settings')
app.autodiscover_tasks(settings.INSTALLED_APPS, related_name='tasks')
if "test" in sys.argv:
app.conf.update(
CELERY_ALWAYS_EAGER=True,
)
print >> sys.stderr, 'CELERY_ALWAYS_EAGER = True'
CELERYBEAT_SCHEDULE = {
'test_rabbit_running': {
"task": "retail.tasks.test_rabbit_running",
"schedule": 3600, #every hour
},
[..]
app.conf.update(
CELERYBEAT_SCHEDULE=CELERYBEAT_SCHEDULE
)
零售/ tasks.py :
from cloud.celery import app
import logging
from celery.utils.log import get_task_logger
logger = get_task_logger('tasks')
logger.setLevel(logging.DEBUG)
@app.task
def test_rabbit_running():
import datetime
utcnow = datetime.datetime.now()
logger.info('CELERY RUNNING')
当我尝试访问无效的网址时发生错误,例如/ foobar。
以下是完整的追溯:
Traceback (most recent call last):
File "/opt/virtenvs/django_slice/local/lib/python2.7/site-packages/gunicorn/workers/sync.py", line 126, in handle_request
respiter = self.wsgi(environ, resp.start_response)
File "/opt/virtenvs/django_slice/local/lib/python2.7/site-packages/django/core/handlers/wsgi.py", line 255, in __call__
response = self.get_response(request)
File "/opt/virtenvs/django_slice/local/lib/python2.7/site-packages/django/core/handlers/base.py", line 178, in get_response
response = self.handle_uncaught_exception(request, resolver, sys.exc_info())
File "/opt/virtenvs/django_slice/local/lib/python2.7/site-packages/django/core/handlers/base.py", line 220, in handle_uncaught_exception
if resolver.urlconf_module is None:
File "/opt/virtenvs/django_slice/local/lib/python2.7/site-packages/django/core/urlresolvers.py", line 342, in urlconf_module
self._urlconf_module = import_module(self.urlconf_name)
File "/opt/virtenvs/django_slice/local/lib/python2.7/site-packages/django/utils/importlib.py", line 35, in import_module
__import__(name)
File "/opt/src/slicephone/cloud/cloud/urls.py", line 52, in
urlpatterns += patterns('', url(r'^search/', include('search.urls')))
File "/opt/virtenvs/django_slice/local/lib/python2.7/site-packages/django/conf/urls/__init__.py", line 25, in include
urlconf_module = import_module(urlconf_module)
File "/opt/virtenvs/django_slice/local/lib/python2.7/site-packages/django/utils/importlib.py", line 35, in import_module
__import__(name)
File "/opt/src/slicephone/cloud/search/urls.py", line 5, in
from handlers import SearchHandler
File "/opt/src/slicephone/cloud/search/handlers.py", line 15, in
from places import handlers as placeshandler
File "/opt/src/slicephone/cloud/places/handlers.py", line 23, in
import api as placesapi
File "/opt/src/slicephone/cloud/places/api.py", line 9, in
from djapi import *
File "/opt/src/slicephone/cloud/places/djapi.py", line 26, in
from tasks import add_single_place, add_multiple_places
File "/opt/src/slicephone/cloud/places/tasks.py", line 2, in
from cloud.celery import app
File "/opt/src/slicephone/cloud/cloud/celery.py", line 4, in
from celery import Celery
File "/opt/src/slicephone/cloud/cloud/celery.py", line 4, in
from celery import Celery
ImportError: cannot import name Celery
答案 0 :(得分:53)
将以下行添加到cloud / celery.py:
import celery
print celery.__file__
给了我文件本身而不是库中的celery模块。将celery.py重命名为celeryapp.py并调整导入后,所有错误都消失了。
注意:
这导致了工人的改变:
celery worker --app=cloud.celeryapp:app
对于那些运行celery == 3.1.2并且收到此错误的人:
TypeError: unpack_from() argument 1 must be string or read-only buffer, not memoryview
答案 1 :(得分:39)
使用Django 1.7.5,Celery 3.1.17和Python 2.7.6,我发现我仍然得到这些ImportError: cannot import name Celery
。但只有在PyCharm 4.0.4下运行测试时。
我发现 的解决方案依赖于from __future__ import absolute_import
First Steps with Django中所述的proj/proj/celery.py
。相反,我将proj/proj/celery_tasks.py
重命名为__init__.py
,然后将from .celery_tasks import app as celery_app
的内容更改为匹配:celery.py
。不再有多个名为{{1}}的文件实例导致导入混淆似乎是一种更简单的方法。
答案 2 :(得分:7)
您是否添加了该行:
from __future__ import absolute_import
到cloud/celery.py
模块的顶部?
在此处阅读示例的细分: http://docs.celeryproject.org/en/latest/django/first-steps-with-django.html
答案 3 :(得分:7)
得到了同样的错误
我的芹菜设置文件名是(celery.py)与“芹菜”相矛盾的#39;包...
所以这样做 - >来自芹菜进口芹菜, 它引起了错误 - 无法导入名称Celery
解决方案 - >只需更改' celery.py'其他类似于&#ce; celery-settings.py'
答案 4 :(得分:6)
为我工作(在服务器中部署后出现一些错误): 从项目中删除所有* .pyc文件并重新启动它。
答案 5 :(得分:3)
我得到了同样的错误。事实证明我的Celery版本存在问题。我已升级到3.1, celeryd 现已弃用此版本(http://celery.readthedocs.org/en/latest/whatsnew-3.1.html)。所以我不得不降级到3.0.19版本,这是之前用于该项目的稳定版本,到目前为止它运行良好。
pip install celery==3.0.19
无论如何,如果你不想降级,3.1版本中芹菜的替代品是芹菜工人。点击此处了解详情:http://celery.readthedocs.org/en/latest/userguide/workers.html。
希望这有帮助! :)
答案 6 :(得分:2)
对于想知道导致此错误的原因的人:
我刚刚遇到这个问题,然后我发现了问题--- sys.path
也许你像我一样添加一些sys.path路径,我在manage.py,
ROOT_PATH = os.path.dirname(os.path.abspath(__file__))
SRC_PATH = os.path.join(ROOT_PATH, 'src')
CONF_PATH = os.path.join(ROOT_PATH, 'conf')
sys.path.insert(0, SRC_PATH)
sys.path.insert(0, CONF_PATH)
所以,from celery import Celery
会首先搜索SRC_PATH
和CONF_PATH
中的芹菜,这就是问题所在。
更改为
sys.path.append(SRC_PATH)
sys.path.append(CONF_PATH)
首先会在python的lib
和site-packages
中进行搜索。解决得很好。
答案 7 :(得分:1)
请注意,较旧的Django项目在项目目录所在的目录中具有manage.py
脚本。也就是说,结构如下所示:
- proj/
- proj/__init__.py
- proj/celery.py
- proj/urls.py
- proj/manage.py
- proj/settings.py
而不是:
- proj/
- proj/__init__.py
- proj/celery.py
- proj/settings.py
- proj/urls.py
- manage.py
在这种情况下,您只需将celery.app
文件重命名为不同的文件,例如上面接受的答案中建议的celeryapp.py
。
答案 8 :(得分:0)
我得到了同样的错误。
似乎from __future__ import absolute_import
不适用于Python 2.6.1,仍然没有引发错误。
升级到Python 2.7.5并且它刚刚起作用。
答案 9 :(得分:0)
我遇到了类似的问题: 从芹菜进口芹菜 ImportError:无法从“芹菜”导入名称“ Celery”
另一种简单的解决方法: 如果您的软件包在celery.py中具有celery配置,这就是引起问题的原因。 重命名为celery_settings.py