【问题标题】:django error when using wsgi and virtualenv: could not import settings使用 wsgi 和 virtualenv 时出现 django 错误:无法导入设置
【发布时间】: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


    【解决方案1】:

    你在哪里添加 '/usr/local/pythonenv/election/src/dev' 到 sys.path?

    您还使 WSGI 文件的其余部分变得比需要的复杂。

    一定要去观看:

    http://code.google.com/p/modwsgi/wiki/WhereToGetHelp?tm=6#Conference_Presentations

    另请阅读:

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

    并使用 activate_this 方法来激活演示中提到的虚拟环境。

    【讨论】:

    • 当我将项目目录添加到 sys.path 时,我开始收到错误,表明它没有看到正确版本的 Django。配置不当:导入中间件 django.middleware.csrf 时出错:“没有名为 csrf 的模块”
    • 在放弃灵活的 WSGI 文件以支持 Graham 更简化的方法后,将项目目录添加到我的 sys.path 并调用 activate_this 方法,一切似乎都正常工作。谢谢。
    猜你喜欢
    • 2012-11-25
    • 1970-01-01
    • 1970-01-01
    • 2012-02-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多