尝试配置django应用程序以使用mod_wsgi

时间:2017-01-20 22:37:56

标签: python django apache wsgi

当我访问此项目的URL时,我在apache error.log中一直收到此错误:

[Fri Jan 20 21:04:16.143990 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326] mod_wsgi (pid=18618): Target WSGI script '/srv/botbot/src/botbot/botbot/wsgi.py' cannot be loaded as Python module. 
[Fri Jan 20 21:04:16.144124 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326] mod_wsgi (pid=18618): Exception occurred processing WSGI script '/srv/botbot/src/botbot/botbot/wsgi.py'. 
[Fri Jan 20 21:04:16.144195 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326] Traceback (most recent call last): 
[Fri Jan 20 21:04:16.144255 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/srv/botbot/src/botbot/botbot/wsgi.py", line 9, in <module> 
[Fri Jan 20 21:04:16.144335 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     application = get_wsgi_application() 
[Fri Jan 20 21:04:16.144381 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/srv/botbot/lib/python2.7/site-packages/django/core/wsgi.py", line 14, in get_wsgi_application 
[Fri Jan 20 21:04:16.144437 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     django.setup() 
[Fri Jan 20 21:04:16.144487 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/srv/botbot/lib/python2.7/site-packages/django/__init__.py", line 17, in setup 
[Fri Jan 20 21:04:16.144540 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     configure_logging(settings.LOGGING_CONFIG, settings.LOGGING) 
[Fri Jan 20 21:04:16.144586 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/srv/botbot/lib/python2.7/site-packages/django/conf/__init__.py", line 48, in __getattr__ 
[Fri Jan 20 21:04:16.144638 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     self._setup(name) 
[Fri Jan 20 21:04:16.144675 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/srv/botbot/lib/python2.7/site-packages/django/conf/__init__.py", line 44, in _setup 
[Fri Jan 20 21:04:16.144711 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     self._wrapped = Settings(settings_module) 
[Fri Jan 20 21:04:16.144747 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/srv/botbot/lib/python2.7/site-packages/django/conf/__init__.py", line 92, in __init__ 
[Fri Jan 20 21:04:16.144793 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     mod = importlib.import_module(self.SETTINGS_MODULE) 
[Fri Jan 20 21:04:16.144822 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/usr/lib/python2.7/importlib/__init__.py", line 37, in import_module 
[Fri Jan 20 21:04:16.144856 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     __import__(name) 
[Fri Jan 20 21:04:16.144884 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/srv/botbot/src/botbot/botbot/settings/__init__.py", line 1, in <module> 
[Fri Jan 20 21:04:16.144930 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     from base import * 
[Fri Jan 20 21:04:16.145008 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/srv/botbot/src/botbot/botbot/settings/base.py", line 27, in <module> 
[Fri Jan 20 21:04:16.145053 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     SECRET_KEY = os.environ['WEB_SECRET_KEY'] 
[Fri Jan 20 21:04:16.145085 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]   File "/usr/lib/python2.7/UserDict.py", line 23, in __getitem__ 
[Fri Jan 20 21:04:16.145118 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326]     raise KeyError(key) 
[Fri Jan 20 21:04:16.145157 2017] [:error] [pid 18618:tid 140192977487616] [remote 66.90.146.30:326] KeyError: 'WEB_SECRET_KEY' 

这是我的wsgi.py文件:

import os 

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

# This application object is used by any WSGI server configured to use this 
# file. This includes Django's development server, if the WSGI_APPLICATION 
# setting points here. 
from django.core.wsgi import get_wsgi_application 
application = get_wsgi_application() 

这是我的.env文件:

# Required 
SECRET_KEY='password1' 
WEB_PORT=8000 
EMAIL_BACKEND='django.core.mail.backends.console.EmailBackend' 
GOPATH=$VIRTUAL_ENV 
WEB_SECRET_KEY='password1' 
STORAGE_URL=postgres://ubuntu:password@localhost:5432/botbot 
REDIS_PLUGIN_STORAGE_URL=redis://localhost:6379/0 
REDIS_PLUGIN_QUEUE_URL=redis://localhost:6379/1 
PUSH_STREAM_URL=http://localhost:8080/pub/?id={id} 

# Set encoding if the system hasn't done it properly 
LANG=en_US.UTF-8 
PYTHONIOENCODING=utf8 

# Optional 
# MEMCACHE_URL=127.0.0.1:11211 
# STATIC_ROOT=/var/www/botbot/static 
# MEDIA_ROOT=/var/www/botbot/uploads 
# DEBUG=True 
# SMTP_URL=smtp://user:pass@host:port 
# SMTP_TLS=True 
# ALLOWED_HOSTS=host1,host2 
# INCLUDE_DJANGO_ADMIN=False 
# EXCLUDE_NICKS=nick1,nick2 

这是我的apache conf文件:

<VirtualHost *:80> 
        ServerName server.test.com 
        ErrorLog ${APACHE_LOG_DIR}/error.log 
        SetEnv WEB_SECRET_KEY password1 
        CustomLog ${APACHE_LOG_DIR}/access.log combined 
        DocumentRoot /srv/botbot/src/botbot 
        <Directory /srv/botbot/src/botbot/botbot> 
                <Files wsgi.py> 
                        Require all granted 
                </Files> 
        </Directory> 

        WSGIDaemonProcess botbot python-path=/srv/botbot/src/botbot/botbot:/srv/botbot/lib/python2.7/site-packages 
        WSGIProcessGroup botbot 
        WSGIScriptAlias / /srv/botbot/src/botbot/botbot/wsgi.py 

</VirtualHost> 

这是我尝试构建的应用:https://github.com/BotBotMe/botbot-web

正如您所看到的,我已尝试在apache conf中设置SetEnv变量,但没有运气。我甚至不确定这是否正确,无论我做什么,我仍然会收到以下错误。

2 个答案:

答案 0 :(得分:0)

我相信您应该尝试使用SetEnvIf指令,因为阅读apache文档:

The internal environment variables set by this directive are set after   
most early request processing directives are run, such as access 
control and URI-to-filename mapping. If the environment variable you're 
setting is meant as input into this early phase of processing such as 
the RewriteRule directive, you should instead set the environment  
variable with SetEnvIf.

如果您想通过SetEnv进行设置,它可能在启动时不适用于django应用程序。

但是你可以做的最好的事情就是在一些预运行的脚本中设置这个env变量。

快乐的编码!

答案 1 :(得分:0)

我最后将以下行添加到我的wsgi.py文件中:

os.environ['WEB_SECRET_KEY'] = 'password'

其中&#39;密码&#39;等于._Sv文件中为WEB_SECRET_KEY变量指定的密码字符串。

我还必须以递归方式将/ srv目录(包含应用程序而不包含其他内容)添加到www-data用户。

本文档很有帮助:https://gist.github.com/GrahamDumpleton/b380652b768e81a7f60c