mod_wsgi не может найти мои пакеты Python? - PullRequest
2 голосов
/ 07 января 2012

Моё приложение django, загруженное в Apache / mod_wsgi, не может найти мои внешние пакеты, даже если я указал его в sys.path?

Настройка выглядит следующим образом:

a) внешние пакетыв / var / www / site / my / python / config

b) веб-сайт django (с файлом settings.py) находится в / var / www / site / domain

c)файл конфигурации wsgi:

import os, sys
sys.stdout = sys.stderr

# Add the virtual Python environment site-packages directory to the path
import site
site.addsitedir('/var/www/virtualenv/lib/python2.6/site-packages')

# Avoid ``[Errno 13] Permission denied: '/var/www/.python-eggs'`` messages
os.environ['PYTHON_EGG_CACHE'] = '/var/www/egg-cache'

# Add project directory to PYTHONPATH
sys.path.append('/var/www/site') # <---- THIS SHOULD FIND EXTERNAL PACKAGES?
os.environ['DJANGO_SETTINGS_MODULE'] = 'domain.settings'

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

d) файл settings.py начинается со следующего:

print "prior to import"
from my.python.config import ConfigParser # <---- THIS EXIST AS INDICATED IN a), but fails!
print after to import"

DEBUG = True
TEMPLATE_DEBUG = DEBUG

ADMINS = (
    # ('Your Name', 'your_email@example.com'),
)

MANAGERS = ADMINS

....

Я получаю следующую ошибку:

prior to import
mod_wsgi (pid=3465): Exception occurred processing WSGI script '/var/www/mod_wsgi/django.wsgi'.
Traceback (most recent call last):
   File "/var/www/virtualenv/lib/python2.6/site-packages/django/core/handlers/wsgi.py", line 250, in __call__
  self.load_middleware()
   File "/var/www/virtualenv/lib/python2.6/site-packages/django/core/handlers/base.py", line 39, in load_middleware
     for middleware_path in settings.MIDDLEWARE_CLASSES:
   File "/var/www/virtualenv/lib/python2.6/site-packages/django/utils/functional.py", line 276, in __getattr__
     self._setup()
   File "/var/www/virtualenv/lib/python2.6/site-packages/django/conf/__init__.py", line 42, in _setup
     self._wrapped = Settings(settings_module)
   File "/var/www/virtualenv/lib/python2.6/site-packages/django/conf/__init__.py", line 89, in __init__
     raise ImportError("Could not import settings '%s' (Is it on sys.path?): %s" % (self.SETTINGS_MODULE, e))
 ImportError: Could not import settings 'domain.settings' (Is it on sys.path?): No module named python.config

Вы видите, что файл settings.py загружается при печати «до импорта», но код не выполняется при импорте «my.python.config.ConfigParser».Кажется, вместо этого он обнаруживает его как python.config?

Есть какие-нибудь подсказки?

Я рвал на себе волосы весь день.Однако все работает как в среде eclipse, так и непосредственно вызывая django-admin.py runserver 80 после установки пути к python и переменных среды django.Я также проверил, что путь к Python находится в sys.path.

У меня закончились идеи, поэтому ЛЮБАЯ помощь будет принята с благодарностью!

Ответы [ 2 ]

1 голос
/ 07 января 2012

Добавить при запуске settings.py:

import my
print my.__file__

Убедитесь, что распечатанный путь соответствует ожидаемому вами пакету "my".

Другими словами, это может быть другой пакет 'my' из-за того, что такой пакет существует в нескольких местах и ​​порядок sys.path неверен.

Также обязательно прочитайте:

http://code.google.com/p/modwsgi/wiki/VirtualEnvironments

, в котором говорится о проблемах с порядком sys.path.

0 голосов
/ 07 января 2012

Есть ли у вас __init__.py во всех подкаталогах и дочерних элементах / var / www / site

, когда вы обращаетесь к my.python.config, __init__.py должно быть там, внутри моего каталога, pythonкаталог и каталог конфигурации.

Что касается разрешения, wsgi будет работать как пользователь apache (пользователь, которого вы указали в wsgi.conf).Заботиться о нем.

...