49

我在这里经历了这个例子:

http://docs.celeryproject.org/en/latest/django/first-steps-with-django.html

我所有的任务都在名为 tasks.py 的文件中。

更新 celery 并从示例 django 添加文件后,无论我尝试什么,都会引发以下错误:

ImportError: cannot import name Celery

问题可能是由以下原因引起的吗?

app.autodiscover_tasks(settings.INSTALLED_APPS, related_name='tasks')

因为它遍历所有具有以下导入的 tasks.py 文件。

from cloud.celery import app

云/芹菜.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')

当我尝试访问无效的 url(如 /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
4

10 回答 10

66

将以下行添加到 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

应用此处提到的补丁:https ://github.com/celery/celery/issues/1637

于 2013-11-13T00:18:44.307 回答
50

使用 Django 1.7.5、Celery 3.1.17 和 Python 2.7.6,我发现我仍然得到这些ImportError: cannot import name Celery. 但仅在 PyCharm 4.0.4 下运行测试时。

我发现一个解决方案依赖于First Steps with Djangofrom __future__ import absolute_import中的描述。相反,我重命名为,然后将内容更改为匹配:。不再有多个文件实例被命名为导致导入混淆似乎是一种更简单的方法。proj/proj/celery.pyproj/proj/celery_tasks.py__init__.pyfrom .celery_tasks import app as celery_appcelery.py

于 2015-03-02T16:34:51.273 回答
15

得到同样的错误

我的芹菜设置文件名(celery.py)与“芹菜”包冲突......

因此,在执行此操作时-> from celery import Celery 出现错误-无法导入名称 Celery

解决方案->只需将“celery.py”更改为“celery-settings.py”之类的其他内容

于 2018-03-12T12:22:35.170 回答
9

为我工作(在服务器中部署后的一些错误):从项目中删除所有 *.pyc 文件并重新启动他。

于 2015-06-17T14:53:19.393 回答
8

您是否添加了以下行:

from __future__ import absolute_import

cloud/celery.py模块的顶部?

在此处阅读示例的细分:http: //docs.celeryproject.org/en/latest/django/first-steps-with-django.html

于 2013-11-12T13:23:24.190 回答
4

我得到了同样的错误。原来我的 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 版本中 celeryd 的替代品是celery worker。在这里查看更多信息:http ://celery.readthedocs.org/en/latest/userguide/workers.html 。

希望这可以帮助!:)

于 2015-04-21T09:32:50.533 回答
3

对于想知道导致此错误的原因的人
我刚才遇到了这个问题,然后我发现了问题--- 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_PATHCONF_PATH

改成

sys.path.append(SRC_PATH)
sys.path.append(CONF_PATH)

它会在 python 中搜索libsite-packages首先搜索。完美解决。

于 2014-07-30T06:17:57.453 回答
2

我遇到了类似的问题: from celery import Celery ImportError: cannot import name 'Celery' from 'celery'

解决此问题的另一种简单方法:如果您的包在 celery.py 中有 celery 配置,这就是导致问题的原因。将其重命名为 celery_settings.py

于 2020-08-27T11:20:36.483 回答
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上面接受的答案中所建议的那样。

于 2014-10-16T20:41:14.627 回答
0

我得到了同样的错误。

似乎from __future__ import absolute_import不适用于 Python 2.6.1,仍然没有引发错误。

升级到 Python 2.7.5,它就可以工作了。

于 2014-03-07T04:55:25.150 回答