Я только что закончил настраивать django приложение на virtualenv, развертывание пошло гладко с помощью сценария матрицы, но теперь .wsgi не работает, я попробовал каждое изменение в Интернете, но никакой удаче. Мой .wsgi файл:
import os
import sys
import django.core.handlers.wsgi
# put the Django project on sys.path
root_path = os.path.abspath(os.path.dirname(__file__) + '../')
sys.path.insert(0, os.path.join(root_path, 'kcdf'))
sys.path.insert(0, root_path)
os.environ['DJANGO_SETTINGS_MODULE'] = 'kcdf.settings'
application = django.core.handlers.wsgi.WSGIHandler()
Я продолжаю получать ту же ошибку:
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] mod_wsgi (pid=16938): Exception occurred processing WSGI script '/home/kcdfweb/webapps/kcdf.web/releases/current/kcdf/apache/kcdf.wsgi'.
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] Traceback (most recent call last):
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] File "/usr/local/lib/python2.6/dist-packages/django/core/handlers/wsgi.py", line 230, in __call__
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] self.load_middleware()
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] File "/usr/local/lib/python2.6/dist-packages/django/core/handlers/base.py", line 33, in load_middleware
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] for middleware_path in settings.MIDDLEWARE_CLASSES:
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] File "/usr/local/lib/python2.6/dist-packages/django/utils/functional.py", line 269, in __getattr__
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] self._setup()
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] File "/usr/local/lib/python2.6/dist-packages/django/conf/__init__.py", line 40, in _setup
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] self._wrapped = Settings(settings_module)
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] File "/usr/local/lib/python2.6/dist-packages/django/conf/__init__.py", line 75, in __init__
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] raise ImportError, "Could not import settings '%s' (Is it on sys.path? Does it have syntax errors?): %s" % (self.SETTINGS_MODULE, e)
[Sun Apr 18 12:44:30 2010] [error] [client 41.215.123.159] ImportError: Could not import settings 'kcdf.settings' (Is it on sys.path? Does it have syntax errors?): No module named kcdf.settings
моя виртуальная среда находится на/home/user/webapps/kcdfweb, мое приложение является/home/user/webapps/kcdf.web/releases/current/project_name мой wsgi файл home/user/webapps/kcdf.web/releases/current/project_name/apache/project_name.wsgi
Если вы используете virtualenv, вам нужно активировать его в сценарии WSGI, чтобы правильно настроить пути.
root_path = os.path.abspath(os.path.dirname(__file__) + '../')
activate_this = os.path.join(root_path, "bin/activate_this.py")
execfile(activate_this, dict(__file__=activate_this))
Я бы порекомендовал вам ознакомиться с документацией для использования Virtualenv с mod_wsgi. Они предлагают несколько альтернативных подходов для подключения к вашему virtualenv, которые могут сработать для вас лучше.
Вам нужно добавить каталог, который на два выше от вашего файла wsgi, поэтому вместо:
root_path = os.path.abspath(os.path.dirname(__file__) + '../')
у вас должен быть
root_path = os.path.abspath(os.path.join(os.path.dirname(__file__), '../', '../'))
... поскольку ваш файл wsgi находится в каталоге с именем apache
в папке вашего проекта.
Есть ли у вас файл __ init __. Py
в вашем каталоге "kcdf"? Без этого ваш файл настроек не может быть импортирован.
Кроме того, вы должны вызвать site.addsitedir () в каталоге site-packages virtualenv, если вы ожидаете, что сможете импортировать данные из virtualenv. См. документацию mod_wsgi для подробностей. Хотя, если он даже не может импортировать ваши настройки, я не думаю, что это ваша текущая проблема.