我正在尝试使用Apache部署mod_wsgi运行Django应用程序,但是遇到了500内部服务器错误的问题。Apache日志显示:
[Thu Jun 23 14:01:47 2011] [error] [client 152.78.95.64] mod_wsgi (pid=16142): Exception occurred processing WSGI script '/home/user/bms/apache/django.wsgi'.
[Thu Jun 23 14:01:47 2011] [error] [client 152.78.95.64] Traceback (most recent call last):
[Thu Jun 23 14:01:47 2011] [error] [client 152.78.95.64] File "/home/user/bms/apache/django.wsgi", line 13, in <module>
[Thu Jun 23 14:01:47 2011] [error] [client 152.78.95.64] import django.core.handlers.wsgi
[Thu Jun 23 14:01:47 2011] [error] [client 152.78.95.64] ImportError: No module named django.core.handlers.wsgi
我的Apache虚拟主机如下:
<VirtualHost *:80>
DocumentRoot /home/user/bms
<Directory /home/user/bms>
Order allow,deny
Allow from all
</Directory>
WSGIDaemonProcess bms user=user group=user processes=2 threads=25 python-path=/usr/local/lib/python2.7/site-packages
WSGIProcessGroup bms
WSGIScriptAlias / /home/user/bms/apache/django.wsgi
</VirtualHost>
我的应用目录中有一个被引用的 wsgi 文件,权限为 0777:
import os
import sys
path = '/home/user/bms'
if path not in sys.path:
sys.path.append(path)
os.environ['DJANGO_SETTINGS_MODULE'] = 'bms.settings'
import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()
我听说这可能是因为Apache用户没有正确的权限。然而,我不知道如何解决这个问题。我还尝试使用www-data用户启动守护程序,但这并没有解决问题。
编辑:
我通过将虚拟主机文件复制到默认文件中,然后使用a2dissite禁用旧文件来解决了这个问题。但我不知道如何“正确”地设置Apache访问我想要的虚拟主机。
site.addsitedir('/path/to/your/venv/python2.7/site-packages/')
吗? - Campa