2017-06-21 73 views
1

我已經搜索,嘗試和運行幾乎所有的教程可用來運行我的Django應用程序與Apache或甚至Nginx(其中大部分是3歲或4歲以上)。Django WSGI沒有模塊名爲'站點'

我已經成功完成了所有與nginx一起工作的部分,直到我放棄了,現在我嘗試使用apache2,目前唯一的錯誤是使用wsgi.py,其他所有工作正常,但運行

sudo python3 -i /var/www/shinra/shinra/wsgi.py 

給了我以下錯誤:

Traceback (most recent call last): 
    File "/var/www/shinra/shinra/wsgi.py", line 23, in <module> 
    application = get_wsgi_application() 
    File "/home/ubuntu/.local/lib/python3.5/site-packages/django/core/wsgi.py", line 13, in get_wsgi_application 
    django.setup(set_prefix=False) 
    File "/home/ubuntu/.local/lib/python3.5/site-packages/django/__init__.py", line 22, in setup 
    configure_logging(settings.LOGGING_CONFIG, settings.LOGGING) 
    File "/home/ubuntu/.local/lib/python3.5/site-packages/django/conf/__init__.py", line 56, in __getattr__ 
    self._setup(name) 
    File "/home/ubuntu/.local/lib/python3.5/site-packages/django/conf/__init__.py", line 41, in _setup 
    self._wrapped = Settings(settings_module) 
    File "/home/ubuntu/.local/lib/python3.5/site-packages/django/conf/__init__.py", line 110, in __init__ 
    mod = importlib.import_module(self.SETTINGS_MODULE) 
    File "/usr/lib/python3.5/importlib/__init__.py", line 126, in import_module 
    return _bootstrap._gcd_import(name[level:], package, level) 
    File "<frozen importlib._bootstrap>", line 986, in _gcd_import 
    File "<frozen importlib._bootstrap>", line 969, in _find_and_load 
    File "<frozen importlib._bootstrap>", line 944, in _find_and_load_unlocked 
    File "<frozen importlib._bootstrap>", line 222, in _call_with_frames_removed 
    File "<frozen importlib._bootstrap>", line 986, in _gcd_import 
    File "<frozen importlib._bootstrap>", line 969, in _find_and_load 
    File "<frozen importlib._bootstrap>", line 956, in _find_and_load_unlocked 
ImportError: No module named 'shinra' 

我wsgi.py設置如下:

import os 
import sys 

PROJECT_DIR = '/var/www/shinra' 
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "shinra.settings") 
def execfile(filename): 
    globals = dict(__file__ = filename) 
    exec(open(filename).read(), globals) 

activate_this = os.path.join(PROJECT_DIR, 'env/shinra/bin', 'activate_this.py') 
execfile(activate_this) 

從django.core.wsgi進口get_wsgi_application 應用= get_wsgi_application()

我也嘗試用默認wsgi.py無濟於事運行它。 至於項目的其餘部分,它只是一個全新的django項目,除了將虛擬環境放入/var/www/shinra/env/shinra/bin之外,沒有其他任何修改。謝謝,我一直在與此戰鬥一段時間,而我是django的新手。使用apache2運行這個顯然會在apache日誌中產生相同的錯誤。

編輯:這也將是很好的一提的是,我試圖在亞馬遜網絡服務運行此EC2實例

UPDATE:

我嘗試使用gunicorn盡一切從頭開始再次,到目前爲止,它的工作原理,如果IM在我的虛擬環境和運行

/home/ubuntu/venvs/shinra/bin/gunicorn -c /home/ubuntu/shinra/scripts/gunicorn_config.py shinra.wsgi 

但如果我設置,使用主管我得到這個錯誤:

[2017-06-21 05:15:25 +0000] [10320] [INFO] Starting gunicorn 19.7.1 
[2017-06-21 05:15:25 +0000] [10320] [INFO] Listening at: http://0.0.0.0:8000 (10320) 
[2017-06-21 05:15:25 +0000] [10320] [INFO] Using worker: sync 
[2017-06-21 05:15:25 +0000] [10323] [INFO] Booting worker with pid: 10323 
[2017-06-21 05:15:25 +0000] [10323] [ERROR] Exception in worker process 
Traceback (most recent call last): 
    File "/home/ubuntu/venvs/shinra/lib/python3.5/site-packages/gunicorn/arbiter.py", line 578, in spawn_worker 
    worker.init_process() 
    File "/home/ubuntu/venvs/shinra/lib/python3.5/site-packages/gunicorn/workers/base.py", line 126, in init_process 
    self.load_wsgi() 
    File "/home/ubuntu/venvs/shinra/lib/python3.5/site-packages/gunicorn/workers/base.py", line 135, in load_wsgi 
    self.wsgi = self.app.wsgi() 
    File "/home/ubuntu/venvs/shinra/lib/python3.5/site-packages/gunicorn/app/base.py", line 67, in wsgi 
    self.callable = self.load() 
    File "/home/ubuntu/venvs/shinra/lib/python3.5/site-packages/gunicorn/app/wsgiapp.py", line 65, in load 
    return self.load_wsgiapp() 
    File "/home/ubuntu/venvs/shinra/lib/python3.5/site-packages/gunicorn/app/wsgiapp.py", line 52, in load_wsgiapp 
    return util.import_app(self.app_uri) 
    File "/home/ubuntu/venvs/shinra/lib/python3.5/site-packages/gunicorn/util.py", line 352, in import_app 
    __import__(module) 
ImportError: No module named 'shinra' 
[2017-06-21 05:15:25 +0000] [10323] [INFO] Worker exiting (pid: 10323) 
[2017-06-21 05:15:25 +0000] [10320] [INFO] Shutting down: Master 
[2017-06-21 05:15:25 +0000] [10320] [INFO] Reason: Worker failed to boot. 

的gunicorn配置文件是:

command = '/home/ubuntu/venvs/shinra/bin/gunicorn' 
pythonpath = '/home/ubuntu/venvs/shinra/bin/python' 
bind = '0.0.0.0:8000' 
workers = 3 
+0

你不能直接用Python直接運行''wsgi.py''。對於Apache而言,Django指令位於https://docs.djangoproject.com/en/1.11/howto/deployment/wsgi/modwsgi/在你的問題中沒有任何東西可以建議你設置了什麼,所以不可能給出任何指導什麼可能不適用於Apache。 –

回答

1

我終於想通了!我的主管配置丟失了一些參數:

[program:shinra_gunicorn] 
command=/home/ubuntu/venvs/shinra/bin/gunicorn -c /home/ubuntu/shinra/gunicorn_config.py shinra.wsgi 
directory=/home/ubuntu/shinra 
environment=PATH="/home/ubuntu/venvs/shinra/bin" 
autostart=true 
autorestart=true 
stderr_logfile=/var/log/shinra.err.log 
stdout_logfile=/var/log/shinra.out.log 
相關問題