2016-08-16 85 views
0

我正试图通过github将一个django应用部署到heroku。将django应用部署到heroku时出错

我收到以下错误 导入错误:没有模块名为settings.staging

但我下的“设置”文件夹中的“staging.py”文件。

我的GitHub代码是:https://github.com/PramathaMadhavankutty/we_are_social

文件夹结构:

root folder/ 
manage.py 
Procfile 
settings/ 
    staging.py 
... 
project-folder/ 
    wsgi.py 

wsgi.py

import os 

from django.core.wsgi import get_wsgi_application 

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "we_are_social.settings") 

application = get_wsgi_application() 

Procfile

web: gunicorn we_are_social.wsgi:application 

日志文件

2016-08-16T21:43:22.513176+00:00 app[web.1]:  self.callable = self.load() 
2016-08-16T21:43:22.513176+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/gunicorn/app/wsgiapp.py", line 65, in load 
2016-08-16T21:43:22.513177+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/gunicorn/app/wsgiapp.py", line 52, in load_wsgiapp 
2016-08-16T21:43:22.513177+00:00 app[web.1]:  return util.import_app(self.app_uri) 
2016-08-16T21:43:22.513178+00:00 app[web.1]:  application = get_wsgi_application() 
2016-08-16T21:43:22.513178+00:00 app[web.1]: File "/app/we_are_social/wsgi.py", line 17, in <module> 
2016-08-16T21:43:22.513178+00:00 app[web.1]:  __import__(module) 
2016-08-16T21:43:22.513179+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/django/core/wsgi.py", line 13, in get_wsgi_application 
2016-08-16T21:43:22.513179+00:00 app[web.1]:  django.setup() 
2016-08-16T21:43:22.513180+00:00 app[web.1]:  configure_logging(settings.LOGGING_CONFIG, settings.LOGGING) 
2016-08-16T21:43:22.513180+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/django/conf/__init__.py", line 55, in __getattr__ 
2016-08-16T21:43:22.513179+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/django/__init__.py", line 17, in setup 
2016-08-16T21:43:22.513177+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/gunicorn/util.py", line 357, in import_app 
2016-08-16T21:43:22.513182+00:00 app[web.1]:  __import__(name) 
2016-08-16T21:43:22.513180+00:00 app[web.1]:  self._setup(name) 
2016-08-16T21:43:22.513181+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/django/conf/__init__.py", line 43, in _setup 
2016-08-16T21:43:22.513181+00:00 app[web.1]:  self._wrapped = Settings(settings_module) 
2016-08-16T21:43:22.513181+00:00 app[web.1]:  mod = importlib.import_module(self.SETTINGS_MODULE) 
2016-08-16T21:43:22.513182+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/importlib/__init__.py", line 37, in import_module 
2016-08-16T21:43:22.513181+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/django/conf/__init__.py", line 99, in __init__ 
2016-08-16T21:43:22.536787+00:00 app[web.1]: [2016-08-16 21:43:22 +0000] [3] [INFO] Reason: Worker failed to boot. 
2016-08-16T21:43:22.513356+00:00 app[web.1]: [2016-08-16 21:43:22 +0000] [10] [INFO] Worker exiting (pid: 10) 
2016-08-16T21:43:22.536539+00:00 app[web.1]: [2016-08-16 21:43:22 +0000] [3] [INFO] Shutting down: Master 
2016-08-16T21:43:22.513183+00:00 app[web.1]: ImportError: No module named settings.staging 
2016-08-16T21:45:48.063161+00:00 heroku[run.3662]: Process exited with status 0 
2016-08-16T21:45:48.038116+00:00 heroku[run.3662]: State changed from up to complete 

是否有人可以帮助我理清了这一点?提前致谢。

回答

3

只需在您的设置文件夹中创建一个空的__init__.py文件(您现在缺少它)。它会表明该文件夹是一个包,因此它的文件可以imoprted

+0

非常感谢。现在它的工作。 – jkpr