如何停止获取ImportError:在将django与wsgi一起使用时无法导入设置'mofin.settings'?

时间:2009-09-11 14:58:37

标签: python django apache wsgi

我无法让wsgi为我的项目'mofin'导入我的设置文件。

apache错误日志中的错误列表如下

mod_wsgi (pid=4001): Exception occurred within WSGI script '/var/www/wsgi-scripts/django.wsgi'.
Traceback (most recent call last):
  File "/usr/lib/python2.5/site-packages/django/core/handlers/wsgi.py", line 228, in __call__
    self.load_middleware()
  File "/usr/lib/python2.5/site-packages/django/core/handlers/base.py", line 31, in load_middleware
    for middleware_path in settings.MIDDLEWARE_CLASSES:
  File "/usr/lib/python2.5/site-packages/django/conf/__init__.py", line 28, in __getattr__
    self._import_settings()
  File "/usr/lib/python2.5/site-packages/django/conf/__init__.py", line 59, in _import_settings
    self._target = Settings(settings_module)
  File "/usr/lib/python2.5/site-packages/django/conf/__init__.py", line 94, in __init__
    raise ImportError, "Could not import settings '%s' (Is it on sys.path? Does it have syntax errors?): %s" % (self.SETTINGS_MODULE, e)
ImportError: Could not import settings 'mofin.settings' (Is it on sys.path? Does it have syntax errors?): No module named mofin.settings

我得到了“你好世界!”这里列出的wsgi应用程序(http://code.google.com/p/modwsgi/wiki/QuickConfigurationGuide)工作正常。

使用python manage.py(runserver | shell | syncdb | test store)可以很好地加载settings.py文件 和应用程序一样。

这是我的wsgi文件:

import os
import sys
sys.path.append('/home/django/mofin/trunk')
sys.path.append('/home/django/mofin/trunk/mofin')
print >> sys.stderr, sys.path
os.environ['DJANGO_SETTINGS_MODULE'] = 'mofin.settings'

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

错误日志中打印的sys.path是

  

['/ usr / lib / python25.zip','/ usr / lib / python2.5','/ usr / lib / python2.5 / plat-linux2','/ usr / lib / python2.5 / lib-tk','/ usr / lib / python2.5 / lib-dynload','/ usr / lib / python2.5 / site-package','/ usr / lib / python2.5 / site-package / gtk-2.0','/ home / django / mofin / trunk','/ home / django / mofin / trunk / mofin']

如果我使用manage.py打开交互式shell,则sys.path为

  

['/ home / django / mofin / trunk / mofin','/ usr / lib / python25.zip','/ usr / lib / python2.5','/ usr / lib / python2.5 /plat -linux2','/ usr / lib / python2.5 / lib -tk','/ usr / lib / python2.5 / lib-dadload','/ usr / lib / python2.5 / site-package',' /usr/lib/python2.5/site-packages/gtk-2.0' ]

我的django设置文件如下所示:     #mofin为mofin项目设置。

DEBUG = True
TEMPLATE_DEBUG = DEBUG

ADMINS = (
    # ('Dan xxxx', 'xxxx@yyyyyyyyyy.com'),
)

MANAGERS = ADMINS

DATABASE_ENGINE = 'mysql'           # 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
DATABASE_NAME = 'mofin'             # Or path to database file if using sqlite3.
DATABASE_USER = 'aaaaaa'             # Not used with sqlite3.
DATABASE_PASSWORD = 'bbbbbb'         # Not used with sqlite3.
DATABASE_HOST = ''             # Set to empty string for localhost. Not used with sqlite3.
DATABASE_PORT = ''             # Set to empty string for default. Not used with sqlite3.

# Local time zone for this installation. Choices can be found here:
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
# although not all choices may be available on all operating systems.
# If running in a Windows environment this must be set to the same as your
# system time zone.
TIME_ZONE = 'Europe/London'

# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = 'en-GB'

SITE_ID = 1

# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = True

# Absolute path to the directory that holds media.
# Example: "/home/media/media.lawrence.com/"
MEDIA_ROOT = '/home/django/media/'

# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash if there is a path component (optional in other cases).
# Examples: "http://media.lawrence.com", "http://example.com/media/"
MEDIA_URL = 'http://mofin.mywebsite.co.uk/media/'

# URL prefix for admin media -- CSS, JavaScript and images. Make sure to use a
# trailing slash.
# Examples: "http://foo.com/media/", "/media/".
ADMIN_MEDIA_PREFIX = '/admin_media/'

# Make this unique, and don't share it with anybody.
SECRET_KEY = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'

# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
    'django.template.loaders.filesystem.load_template_source',
    'django.template.loaders.app_directories.load_template_source',
#     'django.template.loaders.eggs.load_template_source',
)

MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
)

ROOT_URLCONF = 'mofin.urls'

TEMPLATE_DIRS = (
    # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
    # Always use forward slashes, even on Windows.
    # Don't forget to use absolute paths, not relative paths.
)

INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.admin',
    'mofin.store'
)

15 个答案:

答案 0 :(得分:48)

如果您有一个名为与项目相同的应用程序(项目的子目录,其中包含一个init文件),也会发生这种情况。您的settings.py文件可能位于项目文件夹中,但似乎django系统的一部分首先查找项目内部的模块,其名称与项目相同,并且当它在那里找不到settings.py时,它失败了一个误导性的消息。

-uniquename1

---settings.py

---manage.py

---application1

-----file.py

-----file2.py

---uniquename1  (problem, rename this to some other unique name)

-----file.py

-----file2.py

还有别的东西可以检查是否有其他人遇到此问题。适用于Django 1.3和其他人。

答案 1 :(得分:22)

我有类似的权限问题,虽然我的settings.py拥有正确的权限,但.pyc却没有!所以要注意这一点。

答案 2 :(得分:18)

嘿,只是为这个问题添加了一个额外的答案。我有完全相同的问题,但它不是文件权限。我附加了“path / to / project”,但没有附加“path / to”。链接是mod_wsgi的Django integration explanation,它向我展示了答案。

答案 3 :(得分:8)

我找到了答案......文件权限。 / home / django设置为700.即只有django可以查看内容。 apache作为Apache运行,因此无法通过/ home / django。

答案 4 :(得分:7)

我认为在加载django之前,你需要在apache中的wsgi脚本中使用前导斜杠。

import os
import sys
sys.path.append('/home/django/mofin/trunk/')
sys.path.append('/home/django/mofin/trunk/mofin/')
print >> sys.stderr, sys.path
os.environ['DJANGO_SETTINGS_MODULE'] = 'mofin.settings'

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

就我而言

import os
import sys
if os.uname()[1] == 'vivien':
    sys.path.append('/home/www/sitebuilder.blacknight.ie/web/')
    os.environ['DJANGO_SETTINGS_MODULE'] = 'gibo.dev_settings'
elif os.uname()[1] == 'thingy':
    sys.path.append('/home/www/sitebuilder.blacknight.ie/web/')
    os.environ['DJANGO_SETTINGS_MODULE'] = 'gibo.dev_settings'
else:
    sys.path.append('/home/www/sitebuilder.blacknight.ie/web/')
    os.environ['DJANGO_SETTINGS_MODULE'] = 'gibo.settings'

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

答案 5 :(得分:6)

此问题的另一个原因是您无法将应用程序命名为与另一个python模块相同。例如,我调用了我的site,很少意识到site已经是一个python模块。

你可以通过启动python并运行import sitehelp(site)来检查这一点,它会显示它没有使用你的模块。当django尝试导入不存在的site.settings时,这当然会给您带来错误。

答案 6 :(得分:4)

可能的问题:

你忘了__init__.py文件,它必须在你的项目和你认为用于导入的python模块的所有目录中。

您可以尝试的其他方法是将路径直接添加到manage.py文件中,例如:

import sys

...
...

sys.path.insert(0, '/home/django/mofin/trunk')

我希望它有所帮助

答案 7 :(得分:3)

我有同样的问题,但另一种解决方案:

我的项目文件夹与我的应用程序完全相同。

我有:

/家庭/对myApp
/home/myApp/settings.py
/home/myApp/manage.py
/home/myApp/rights.py
/家庭/对myApp /静态/
/家庭/对myApp /静态/
/home/myApp/myApp/model.py
/home/myApp/myApp/admin.py
/home/myApp/myApp/views.py

这种树似乎不太容易。 我更改了项目根文件夹的名称,问题解决了!

答案 8 :(得分:1)

(我为Django deployment problem in Apache/mod_wsgi. ImportError: Could not import settings 'site.settings'写了同样的答案,以防有人发现这个问题。)

在您的情况下,这似乎不是问题,但是当我使用WSGIPythonPath指令(而不是.wsgi文件)设置sys.path时,我运行了相同的ImportError。这工作正常,直到我切换到以守护进程模式运行WSGI。一旦你这样做,你必须使用WSGIDaemonProcess指令的python-path参数。

答案 9 :(得分:1)

在我的情况下,我有一个导致此错误的循环导入。从settings.py我在另一个模块中导入一个函数,从该模块导入一个设置变量。要修复它,而不是直接从设置导入,我这样做了:

from django.conf import settings

答案 10 :(得分:1)

让我补充一下这个问题的经验。在头部敲打几个小时并从上面的答案中尝试所有后,我发现settings.py文件中的几行导致了问题:

from south.modelsinspector import add_introspection_rules
add_introspection_rules([], ["^dynamicsites.fields.FolderNameField"])
add_introspection_rules([], ["^dynamicsites.fields.SubdomainListField"])

之后我制作了settings.py的副本,命名为scripts_settings.py,然后使用该文件,现在一切正常。

答案 11 :(得分:0)

初看起来我会说python路径错了,但与交互式shell相比它看起来还不错。 所以也许试试这个:

from django.core.management import setup_environ
from mofin import settings

setup_environ(settings)

答案 12 :(得分:0)

我打算说你可以在你的wsgi文件中插入/附加你的项目目录到你的sys.path但如果你的设置文件在

/home/django/mofin/trunk/mofin/settings.py

然后你应该在那里好。

Is it on sys.path? Does it have syntax errors?

这几乎总结了你在寻找什么。

有趣的是错误传播:

for middleware_path in settings.MIDDLEWARE_CLASSES:

但是你看似exact default

您可能想要检查wsgi指向哪个python解释器。您是否打算使用virtualenv,但wsgi正在查看您的系统安装?

您还可以设置运行wsgi的用户和组。我用的是:

WSGIDaemonProcess mysite.com user = skyl group = skyl processes = n threads = N python-path = / home / skyl / pinax / pinax-env2 / lib / python2.6 / site-packages

答案 13 :(得分:0)

我有类似的问题,在我的python中使用以下片段解决了它:

ALLDIRS = ['/var/www/MarkerDB/']

import sys 
import site 

# Remember original sys.path.
prev_sys_path = list(sys.path) 

# Add each new site-packages directory.
for directory in ALLDIRS:
  site.addsitedir(directory)

# Reorder sys.path so new directories at the front.
new_sys_path = [] 
for item in list(sys.path): 
    if item not in prev_sys_path: 
        new_sys_path.append(item) 
        sys.path.remove(item) 
sys.path[:0] = new_sys_pat

来源:http://code.google.com/p/modwsgi/wiki/VirtualEnvironments#Application_Environments

答案 14 :(得分:0)

我刚遇到此错误,解决方案是通过myvenv / source / activate启用我的虚拟环境。