我有一个 django 项目,运行良好,runserver 位于:
D:\EverTabs\work\evertabs-website\src\evertabs\
我的 settings.py 和 manage.py 位于上述路径中。
我打开可信赖的 cmd shell,cd 到该目录并运行manage.py celeryd
,我得到一个异常并出现以下错误:
ImportError: Could not import settings 'evertabs.settings' (Is it on sys.path?): No module named evertabs.settings
很公平。谷歌和 StackOverflow 来救援,我找到了答案。我需要提供--settings=settings
给命令。奇怪,因为 runserver 不需要--settings=settings
,但这就是生活。我愿意妥协。我继续收到错误消息:
Traceback (most recent call last):
File "C:\Progra~1\Python26\lib\multiprocessing\process.py", line 231, in _bootstrap
self.run()
File "C:\Progra~1\Python26\lib\multiprocessing\process.py", line 88, in run
self._target(*self._args, **self._kwargs)
File "c:\program files\python26\lib\site-packages\celery-2.4.6-py2.6.egg\celery\concurrency\processes\pool.py", line 173, in worker
initializer(*initargs)
File "c:\program files\python26\lib\site-packages\celery-2.4.6-py2.6.egg\celery\worker\__init__.py", line 64, in process_initializer
app.loader.init_worker()
File "c:\program files\python26\lib\site-packages\celery-2.4.6-py2.6.egg\celery\loaders\base.py", line 100, in init_worker
self.on_worker_init()
File "c:\program files\python26\lib\site-packages\django_celery-2.4.2-py2.6.egg\djcelery\loaders.py", line 92, in on_worker_init
autodiscover()
File "c:\program files\python26\lib\site-packages\django_celery-2.4.2-py2.6.egg\djcelery\loaders.py", line 114, in autodiscover
for app in settings.INSTALLED_APPS])
File "c:\program files\python26\lib\site-packages\django_celery-2.4.2-py2.6.egg\djcelery\loaders.py", line 124, in find_related_module
app_path = importlib.import_module(app).__path__
File "build\bdist.win32\egg\importlib\__init__.py", line 37, in import_module
ImportError: No module named evertabs
所以我用力地挠了挠头,并决定如果我给这个家伙提供一个不同的 pythonpath,他会很好地放置。我的下一个尝试是:
manage.py celeryd --pythonpath=D:\EverTabs\work\evertabs-website\src\
现在我们到了某个地方!没有错误。但是,与 settings.py 位于同一目录中的 celeryconfig.py 没有得到处理。我的任务都没有加载。我甚至将语法错误放入 celeryconfg.py 以向自己证明它没有被加载。
我做的下一步是使用 django 1.4 中的 manage.py。这个 manage.py 被放置在D:\EverTabs\work\evertabs-website\src\
而不是D:\EverTabs\work\evertabs-website\src\evertabs\
. 此时,我可以用简单的语法执行 celeryd,而不必添加到 pythonpath 中。尽管如此,我的 celeryconfig.py 仍然保持不变:
D:\EverTabs\work\evertabs-website\src>manage.py celeryd
进一步的研究表明,如果我将 tasks.py 添加到我的顶级目录 9 中 setting.py 所在的位置)。Celery 会自动发现它们。这已经奏效了。但是,celeryconfig.py 仍然没有被处理,所以我不能在那里做更复杂的配置。目前,这不是问题,因为我的任务终于找到了。但是,celeryconfig.py 没有被处理,这让我非常困扰。
我现在开始意识到,也许现代 celery 毕竟不是在寻找 celeryconfig.py。我可以简单地将这些设置放在我的 settings.py 中,celery 会选择它们。事情开始看起来不错。