3

我遇到的问题是我的 wsgi 文件无法正确导入 wsgi 处理程序。

/var/log/apache2/error.log报告:

ImportError:没有名为 django.core.handlers.wsgi 的模块

谷歌搜索这带来了几个结果,主要是处理权限错误,因为www-data无法读取某些文件和/或 pythonpath 不正确。有些解决方案含糊不清,或者在我的情况下不起作用。

背景资料..

我的 /usr/lib 目录..

/usr/lib/python2.4
/usr/lib/python2.5
/usr/lib/python2.6
/usr/lib/python-django

默认的 python 版本是 2.5.2。如果我以普通用户身份打开解释器,我可以import django.core.handlers.wsgi毫无问题。

如果我切换到www-datapython版本也是一样的,我可以导入django.core.handlers.wsgi模块没问题。

在我的 bashrc 中,我将 PYTHONPATH 设置为包含我所有 django 站点的主目录...

export PYTHONPATH=/home/meder/django-sites/:$PYTHONPATH

所以目录结构是:

django-sites/
   test

test是创建的目录django-admin createproject

我的虚拟主机:

<VirtualHost *:80>
    ServerName beta.blah.com
    WSGIScriptAlias / /home/meder/django-sites/test/apache/django.wsgi
    Alias /media /home/meder/django-sites/test/media/
</VirtualHost>

/home/meder/django-sites/test/apache/django.wsgi文件本身:

import os, sys

sys.path.append('/usr/local/django')
sys.path.append('/home/meder/django-sites')
sys.path.append('/home/meder/django-sites/test')
os.environ['DJANGO_SETTINGS_MODULE'] = 'test.settings'

import django.core.handlers.wsgi

application = django.core.handlers.wsgi.WSGIHandler()

最后,我的操作系统是 Debian Lenny,我从 backports 中获取了 django 1.1.1。希望这是足够的信息。

更新 #1 - 根据第一个回复,结果如下ldd /usr/lib/apache2/modules/mod_wsgi.so

meder@site:/usr/lib/apache2/modules$ ldd mod_wsgi.so
    libpython2.5.so.1.0 => /usr/lib/libpython2.5.so.1.0 (0xb7d99000)
    libpthread.so.0 => /lib/libpthread.so.0 (0xb7d81000)
    libdl.so.2 => /lib/libdl.so.2 (0xb7d7c000)
    libutil.so.1 => /lib/libutil.so.1 (0xb7d78000)
    libm.so.6 => /lib/libm.so.6 (0xb7d52000)
    libc.so.6 => /lib/libc.so.6 (0xb7c14000)
    /lib/ld-linux.so.2 (0xb7efd000)

所以它是针对 python 2.5 而不是 2.4 编译的。

4

3 回答 3

2

由于我在 Debian 上,看来 django 是 in/usr/lib/pymodules/python2.5而不是/usr/lib/python2.5/site-packages.

我添加了

sys.path.append('/usr/lib/pymodules/python2.5') 

到我的 wsgi 文件的顶部并做到了,尽管我觉得我应该以更适当的方式解决这个问题。

于 2010-02-05T15:55:16.143 回答
1

我认为您的问题不在于 sys.path。我一直在使用守护进程的 Django 中使用 Mod_WSGI,就像这样,

# Note these 2 lines
WSGIDaemonProcess site-1 user=user-1 group=user-1 threads=25
WSGIProcessGroup site-1

Alias /media/ /usr/local/django/mysite/media/

<Directory /usr/local/django/mysite/media>
Order deny,allow
Allow from all
</Directory>

WSGIScriptAlias / /usr/local/django/mysite/apache/django.wsgi

<Directory /usr/local/django/mysite/apache>
Order deny,allow
Allow from all

如果您注意前两行 - 您可以指定将运行此的组和用户。在您的情况下,您提到 www-data 可以导入 django 模块,但是在 Apache 部署它时它不起作用 - 也许该进程正在由没人运行,或者其他一些没有权限导入此模块的用户/组. 添加 DaemonProcess 和 Group 行应该可以解决您的问题。

HTH。

[1] 供参考 - 这是 Django Mod_WSGI 文档 - http://code.google.com/p/modwsgi/wiki/IntegrationWithDjango

于 2010-02-05T18:52:12.180 回答
0

听起来你 mod_wsgi 不是针对 Python 2.5 编译的,而是针对 Python 2.4 或 2.6 编译的。跑:

ldd mod_wsgi.so

在安装它的 mod_wsgi.so 文件上确定它正在使用什么。

如果不同,您将需要从源代码重新编译 mod_wsgi,以便它使用您要使用的版本。

于 2010-02-05T06:03:33.083 回答