Моё приложение 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.
У меня закончились идеи, поэтому ЛЮБАЯ помощь будет принята с благодарностью!