【发布时间】:2012-02-05 04:47:35
【问题描述】:
我已经阅读了大量关于 wsgi 看不到 Django settings.py 文件的帖子,我可以得出的最好结论是我的 Django 项目不在我的 PYTHONPATH 中。
让事情变得复杂的是,我在系统级别运行的是旧版本的 Django,但这个项目需要在 virtualenv 中运行。
我在 /usr/local/pythonenv/election 设置了一个 virtualenv,我的项目位于 /usr/local/pythonenv/election/src/dev/election
我的 .wsgi 文件位于 /usr/local/pythonenv/election/src/dev/election/config/ 中
我可以使用 $ python manage.py runserver 运行 Django 服务器
但是当使用 apache 和 mod_wsgi 时,我得到了错误:
ImportError: Could not import settings 'election.settings' (Is it on sys.path? Does it have syntax errors?): No module named election.settings
这是我的 .wsgi 文件:
import os
import sys
import site
sys.stdout = sys.stderr
HERE = env_root = os.path.abspath(os.path.dirname(__file__))
found = False
while env_root != '/':
env_root = os.path.abspath(os.path.dirname(env_root))
if os.path.exists(os.path.join(env_root, 'bin', 'activate')):
found = True
break
assert found, "didn't find a virtualenv in any parent of %s" % HERE
sitepackages_root = os.path.join(env_root, 'lib')
assert os.path.exists(sitepackages_root), "no such dir %s" % sitepackages_root
for d in os.listdir(sitepackages_root):
if d.startswith('python'):
site.addsitedir(os.path.join(sitepackages_root, d, 'site-packages'))
break
else:
raise RuntimeError("Could not find any site-packages to add in %r" % env_root)
os.environ['DJANGO_SETTINGS_MODULE'] = 'election.settings'
os.environ['PYTHON_EGG_CACHE'] = '/tmp/election-python-eggs'
import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()
这是回溯:
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] File "/usr/lib/pymodules/python2.6/django/core/handlers/base.py", line 33, in load_middleware
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] for middleware_path in settings.MIDDLEWARE_CLASSES:
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] File "/usr/lib/pymodules/python2.6/django/utils/functional.py", line 269, in __getattr__
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] self._setup()
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] File "/usr/lib/pymodules/python2.6/django/conf/__init__.py", line 40, in _setup
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] self._wrapped = Settings(settings_module)
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] File "/usr/lib/pymodules/python2.6/django/conf/__init__.py", line 75, in __init__
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] raise ImportError, "Could not import settings '%s' (Is it on sys.path? Does it have syntax errors?): %s" % (self.SETTINGS_MODULE, e)
[Sat Jan 07 21:54:19 2012] [error] [client 192.168.150.122] ImportError: Could not import settings 'election.settings' (Is it on sys.path? Does it have syntax errors?): No module named election.settings
【问题讨论】:
标签: python django virtualenv wsgi