3

这是我的目录结构的样子(我只包含了相关部分):

my_git_root/
├── Procfile
├── README.md
├── requirements.txt
└── my_django_project
    ├── app1
    │   ├── admin.py
    │   ├── __init__.py
    │   ├── models.py
    │   ├── tests.py
    │   ├── urls.py
    │   └── views.py
    ├── fabfile.py
    ├── app2
    │   ├── __init__.py
    │   ├── models.py
    │   ├── templates
    │   ├── tests.py
    │   └── views.py
    ├── manage.py
    └── my_django_project
        ├── __init__.py
        ├── settings
        │   ├── base.py
        │   ├── __init__.py
        │   ├── local.py
        │   ├── production.py
        │   └── staging.py
        ├── static
        ├── urls.py
        └── wsgi.py

遵循官方 Heroku 文档,这就是我的Procfile

web: gunicorn my_django_project.wsgi

但是当我运行foreman start, 命令时,我得到一个以ImportError: No module named my_django_project.wsgi..

Procfilegit_root/到(Django 项目根目录)移动似乎有效(就像在这篇文章my_django_project/中所做的那样),但仅限于本地——尝试部署到 Heroku 似乎没问题,直到您尝试扩展 Web 进程:

$ heroku ps:scale web=1
Scaling web dynos... failed 
 !    No such process type web defined in Procfile. 

Heroku似乎希望您将 Procfile 放入项目的 git 存储库 root中,但我尝试了很多组合,Procfile但似乎没有一个有效。我也试过:

web: gunicorn my_django_project/my_django_project.wsgi

Procfile但这会导致ImportError: Import by filename is not supported.

指定 python 路径也不起作用;IE

web: gunicorn my_django_project.wsgi:application --pythonpath=/app/my_django_project

抛出错误ImportError: No module named my_django_project.wsgi

但是,使用 gunicorn from 在本地运行git_root/my_django_project/似乎可行:

$ gunicorn -b 0.0.0.0:8000 my_django_project.wsgi:application            
2013-10-15 16:55:31 [5703] [INFO] Starting gunicorn 18.0
2013-10-15 16:55:31 [5703] [INFO] Listening at: http://0.0.0.0:8000 (5703)
2013-10-15 16:55:31 [5703] [INFO] Using worker: sync
2013-10-15 16:55:31 [5708] [INFO] Booting worker with pid: 5708
2013-10-15 16:56:04 [5703] [INFO] Handling signal: winch
2013-10-15 16:56:04 [5703] [INFO] SIGWINCH ignored. Not daemonized

所以我的猜测是我的语法Procfile不正确,但我不确定如何。

4

2 回答 2

7

写这个问题的时候想通了!

我必须做的是将--pythonpath选项设置为指向我的 django 项目根目录,即git_root/my_django_project/.

这就是我的Procfile

web: gunicorn -b 0.0.0.0:8000 --pythonpath=./my_django_project my_django_project.wsgi:application

现在它在本地工作:

$ foreman start
17:04:02 web.1  | started with pid 6327
17:04:02 web.1  | 2013-10-15 17:04:02 [6330] [INFO] Starting gunicorn 18.0
17:04:02 web.1  | 2013-10-15 17:04:02 [6330] [INFO] Listening at: http://0.0.0.0:8000 (6330)
17:04:02 web.1  | 2013-10-15 17:04:02 [6330] [INFO] Using worker: sync
17:04:02 web.1  | 2013-10-15 17:04:02 [6335] [INFO] Booting worker with pid: 6335
17:04:04 web.1  | 2013-10-15 17:04:04 [6330] [INFO] Handling signal: winch
17:04:04 web.1  | 2013-10-15 17:04:04 [6330] [INFO] SIGWINCH ignored. Not daemonized

扩展 Web 流程现在也可以了:

$ heroku ps:scale web=1 --app my-django-project                          
Scaling web dynos... done, now running 1
于 2013-10-15T21:22:10.890 回答
0

使用您的第一个脚手架,您的 Procfile 与 my_django_project 处于同一级别。我这样做了:

网站: cd my_django_project && gunicorn my_django_project.wsgi --log-file -

希望这可以帮助。

- 编辑 -

最好使用下面的行更改此文件。确保你在你的主分支上(我很难从另一个分支推heroku)。

网站:gunicorn --pythonpath my_django_project my_django_project.wsgi --log-file -

于 2014-09-24T06:32:45.603 回答