1

我正在 Debian 系统上使用 apache2 + mod_wsgi 设置 django 服务器(1.4,python 2.7)。从 django 方面来看,一切正常,如果我运行 manage.py runserver,开发服务器会正​​确显示该站点,但是,当我尝试设置我的 apache 服务器以运行 WSGI 时,它无法显示 ValueError。

这是mysite.wsgi

ALLDIRS = ['/usr/local/lib/python2.7/site-packages']
# the above directory depends on the location of your python installation.
# if using virtualenv, it will need to match your projects locale.
import os
import sys
import site

os.environ['DJANGO_SETTINGS_MODULE'] = 'ggDatabase.settings'
prev_sys_path = list(sys.path)
sys.path.append("/usr/local/lib/python2.7")
path = "/home/acad/statsdb/src"
if path not in sys.path:
        sys.path.append(path)
        sys.path.append("/home/acad/statsdb/src/ggDatabase")
for directory in ALLDIRS:
        site.addsitedir(directory)
        new_sys_path = []
        for item in list(sys.path):
            if item not in prev_sys_path:
                new_sys_path.append(item)
                sys.path.remove(item)
                sys.path[:0] = new_sys_path

# change this depending on your project.

site.addsitedir("/home/acad/statsdb/src/ggDatabase/")


os.environ['PYTHON_EGG_CACHE'] = '/home/acad/.python-eggs'
os.environ['SETTINGS_MODULE'] = 'settings'
import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()

这是apache VirtualHost 配置

<VirtualHost 127.0.0.1:8000>
    ServerName mysite.com
    ServerAlias www.mysite.com
    <Directory /home/acad/statsdb/src/ggDatabase>
        Order deny,allow
        Allow from all
    </Directory>

    LogLevel warn
    CustomLog /var/log/apache2/mysite.com.access.log combined
    ErrorLog /var/log/apache2/mysite.com.error.log

    WSGIDaemonProcess mysite.com user=acad group=acad threads=25 python-path=/usr/local/lib/python2.7
    WSGIProcessGroup mysite.com
    WSGIScriptAlias / /home/acad/statsdb/src/ggDatabase/apache/mysite.wsgi

</VirtualHost>

这是我在测试服务器上的确切配置,它在那里工作,但新服务器在尝试运行 wsgi 脚本时遇到问题:

[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1] mod_wsgi (pid=26233): Target WSGI script '/home/acad/statsdb/src/ggDatabase/apache/mysite.wsgi' cannot be loaded as Python module.
[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1] mod_wsgi (pid=26233): Exception occurred processing WSGI script '/home/acad/statsdb/src/ggDatabase/apache/mysite.wsgi'.
[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1] Traceback (most recent call last):
[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1]   File "/home/acad/statsdb/src/ggDatabase/apache/mysite.wsgi", line 31, in <module>
[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1]     import django.core.handlers.wsgi
[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1]   File "/usr/local/lib/python2.7/site-packages/django/core/handlers/wsgi.py", line 8, in <module>
[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1]     from django import http
[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1]   File "/usr/local/lib/python2.7/site-packages/django/http/__init__.py", line 11, in <module>
[Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1]     from urllib import urlencode, quote
 [Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1]   File "/usr/local/lib/python2.7/urllib.py", line 1228, in <module>
 [Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1]     _safe_map[c] = c if (i < 128 and c in always_safe) else '%{:02X}'.format(i)
 [Fri Jun 29 09:38:14 2012] [error] [client 127.0.0.1] ValueError: zero length field name in format

这个错误太笼统了,我真的不知道可能出了什么问题。有任何想法吗?

提前致谢!

布鲁诺

4

1 回答 1

0

解决了。如果有人有类似的错误,请确保打印 sys.version,您可能会发现(和我一样)wsgi 是在另一个已安装的 python 版本下配置的。

如果是这种情况,请使用 --with-python 选项重新安装 mod_wsgi。

于 2012-06-29T20:03:47.063 回答