5

我正在尝试在 Heroku 上运行自定义 django 命令作为计划任务。我可以通过以下方式在本地执行自定义命令:python manage.py send_daily_email. (注意:我对自定义管理命令本身没有任何问题)

但是,当尝试通过 Heroku Scheduler 插件“运行”任务时,Heroku 给了我以下异常:

Traceback (most recent call last):
  File "bin/send_daily_visit_email.py", line 2, in <module>
    from django.conf import settings
ImportError: No module named django.conf

我在/bin/send_daily_email.py中放置了一个 python 脚本,如下所示:

#! /usr/bin/python
from django.conf import settings
settings.configure()
from django.core import management

management.call_command('send_daily_email') #delegates off to custom command

然而,在 Heroku中,我能够运行heroku run bin/python- 启动 python shell - 并成功导入settingsdjango.conf

我很确定这与我的PYTHON_PATH或对 Django 的可见性有关SETTINGS_MODULE,但我不确定如何解决这个问题。有人能指出我正确的方向吗?有没有更简单的方法来完成我在这里尝试做的事情?

非常感谢您提前提供的提示和建议!Heroku 新手!:)

编辑:

根据 Nix 的评论,我做了一些调整,并发现指定我的确切 python 路径,我确实通过了 Django 设置。

我现在收到:

  File "/app/lib/python2.7/site-packages/django/core/management/__init__.py", line 155, in call_command
    raise CommandError("Unknown command: %r" % name)
django.core.management.base.CommandError: Unknown command: 'send_daily_email'

虽然,当我运行“heroku run bin/python app/manage.py”时,我可以看到“send_daily_email”。

如果我遇到答案,我会保持更新。

4

2 回答 2

3

您可能正在使用不同的解释器。

检查以确保 shell python 与您在脚本 /usr/bin/python 中引用的相同。可能是您的路径中有一个不同的路径,这可以解释为什么它在您运行时有效,python manage.py而不是您明确引用的 shell 脚本/usr/bin/python


打字which python会告诉你在你的路径上找到了什么解释器。

于 2011-12-05T04:05:57.113 回答
2

此外,这也可以通过将主目录添加到 Python 路径来解决。一种快速且不显眼的方法是将其添加到 PYTHONPATH 环境变量(通常是 Heroku Cedar 堆栈上的 /app)。

通过 heroku config 命令添加它:

$ heroku config:add PYTHONPATH=/app

应该这样做!更多详情:http ://tomatohater.com/2012/01/17/custom-django-management-commands-on-heroku/

于 2012-01-17T05:49:56.940 回答