如何排除故障-导入错误:无法导入设置';mysite.settings';部署django时?

如何排除故障-导入错误:无法导入设置';mysite.settings';部署django时?,django,apache,debugging,setup-deployment,Django,Apache,Debugging,Setup Deployment,根据apache部署说明,我已经部署了django应用程序,并与apache和mod_python完美配合。但由于我对项目结构做了一些修改,我一直无法使它正常工作。无论我尝试什么,我都会看到以下页面: MOD_PYTHON ERROR ProcessId: 27841 Interpreter: '127.0.0.1' ServerName: '127.0.0.1' DocumentRoot: '/var/www' URI: '/myapp/

根据apache部署说明,我已经部署了django应用程序,并与apache和mod_python完美配合。但由于我对项目结构做了一些修改,我一直无法使它正常工作。无论我尝试什么,我都会看到以下页面:

MOD_PYTHON ERROR

ProcessId:      27841
Interpreter:    '127.0.0.1'

ServerName:     '127.0.0.1'
DocumentRoot:   '/var/www'

URI:            '/myapp/'
Location:       '/myapp/'
Directory:      None
Filename:       '/var/www/myapp'
PathInfo:       '/'

Phase:          'PythonHandler'
Handler:        'django.core.handlers.modpython'

Traceback (most recent call last):

  File "/usr/lib/python2.6/dist-packages/mod_python/importer.py", line 1537, in HandlerDispatch
    default=default_handler, arg=req, silent=hlist.silent)

  File "/usr/lib/python2.6/dist-packages/mod_python/importer.py", line 1229, in _process_target
    result = _execute_target(config, req, object, arg)

  File "/usr/lib/python2.6/dist-packages/mod_python/importer.py", line 1128, in _execute_target
    result = object(arg)

  File "/usr/local/lib/python2.6/dist-packages/Django-1.3.1-py2.6.egg/django/core/handlers/modpython.py", line 212, in handler
    return ModPythonHandler()(req)

  File "/usr/local/lib/python2.6/dist-packages/Django-1.3.1-py2.6.egg/django/core/handlers/modpython.py", line 174, in __call__
    self.load_middleware()

  File "/usr/local/lib/python2.6/dist-packages/Django-1.3.1-py2.6.egg/django/core/handlers/base.py", line 39, in load_middleware
    for middleware_path in settings.MIDDLEWARE_CLASSES:

  File "/usr/local/lib/python2.6/dist-packages/Django-1.3.1-py2.6.egg/django/utils/functional.py", line 276, in __getattr__
    self._setup()

  File "/usr/local/lib/python2.6/dist-packages/Django-1.3.1-py2.6.egg/django/conf/__init__.py", line 42, in _setup
    self._wrapped = Settings(settings_module)

  File "/usr/local/lib/python2.6/dist-packages/Django-1.3.1-py2.6.egg/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 'settings' (Is it on sys.path?): No module named settings
读取各种线程时,问题可能是以下之一

  • 不正确的apache配置文件
  • 系统路径不正确
  • 对任何文件或目录的权限都不正确
  • django站点代码中的bug
有没有办法缩小这个问题的范围?例如,有没有办法找出发生错误时的sys.path?这里有什么日志文件可以帮助我吗?有没有办法区分“找不到文件”和“没有读取文件的权限”?我想更科学地对待这个解决方案,而不仅仅是尝试随机的事情,直到我偶然发现这个解决方案


此问题与以下问题不同:。我在特别询问如何缩小可能的解决方案的范围,而不是解决方案本身。

好的,我自己解决了这个问题,所以我会回答我自己的问题。 我发现没有apache日志或任何其他信息源来找出导致导入错误的确切原因。因此,我在下面分享我的方法,作为一种更“理性”的方法,希望我能为一些人节省一些令人沮丧的随机更改的时间

作为记录,这里是我使用的apache配置

<Location "/mysite/">
    SetHandler python-program
    PythonHandler django.core.handlers.modpython
    SetEnv DJANGO_SETTINGS_MODULE mysite_django.settings
    PythonOption django.root /mysite
    PythonDebug On
    PythonPath "['/home/mysite/prg/mysite/mysite_django', '/home/mysite/prg/mysite'] + sys.path"
</Location>
按Ctrl-A、Ctrl-C创建新屏幕。 现在,查看与apache完全相同的权限非常重要,因此我切换到运行apache的用户,即debian系统上的www数据:

sudo -i -u www-data
我将尝试自己从python环境导入settings.py:

python

>>> import os, sys
>>> print sys.path
... result omitted ...
这显然应该为您提供没有任何“mysite”目录的标准sys.path,因为我们运行的是纯python。所以我修改了sys.path,如下所示。我直接从apache配置复制粘贴,以避免打字错误:

>>> sys.path = ['/home/mysite/prg/mysite/mysite_django', '/home/mysite/prg/mysite'] + sys.path
>>> import mysite_django.settings
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ImportError: No module named mysite_django.settings
它不存在吗?奇怪

>>> os.path.exists ('/home')
True
>>> os.path.exists ('/home/mysite')
True
>>> os.path.exists ('/home/mysite/prg/')
True
>>> os.path.exists ('/home/mysite/prg/mysite')
True
>>> os.path.exists ('/home/mysite/prg/mysite/mysite_django')
False
在这里,我意识到mysite_django的权限有问题。可能是我做的所有随机改变留下的。但实际上,问题出在上面的目录mysite中,因为它试图从中读取目录列表。我使用Ctrl-A、Ctrl-N切换到超级用户屏幕,并使用
chmod
设置mysite的权限,使其与上一个成功的目录相同:

$ ls -la /home/mysite/prg
total 12
drwxr-xr-x 3 mysite mysite 4096 2011-11-08 11:24 .
drwxr-xr-x 7 mysite mysite 4096 2011-11-08 14:56 ..
drwxr-xr-- 6 mysite mysite 4096 2011-11-08 11:35 mysite
$ chmod o+x /home/mysite/prg/mysite/
$ ls -la /home/mysite/prg
total 12
drwxr-xr-x 3 mysite mysite 4096 2011-11-08 11:24 .
drwxr-xr-x 7 mysite mysite 4096 2011-11-08 14:56 ..
drwxr-xr-x 6 mysite mysite 4096 2011-11-08 11:35 mysite
使用Ctrl-A、Ctrl-N切换回www数据屏幕:

>>> os.path.exists ('/home/mysite/prg/mysite/mysite_django')
True
>>> os.path.exists ('/home/mysite/prg/mysite/mysite_django/settings.py')
True
现在进行最后的测试

>>> import mysite_django.settings
>>>
耶!成功 我们甚至可以进一步测试django是否可以加载

>>> from django.core.management import setup_environ
>>> setup_environ(mysite_django.settings)
'/home/mysite/prg/mysite/mysite_django'
此时,该站点在我的浏览器中再次运行

通过以下步骤,您至少可以确保:

  • 用户www数据的settings.py没有权限问题
  • apache配置的PythonPath设置中没有错误
  • 导入settings.py时没有运行时错误

对于我的Django 1.5和mod_wsgi,我是这样解决的:

httpd.conf:

WSGIScriptAlias /mysite "/var/www/html/mysite/mysite/wsgi.py"
WSGIPythonPath  "/var/www/html/mysite/mysite"
<Directory "/var/www/html/mysite/mysite">
    Order deny,allow
    Allow from all
</Directory>
另一件事,避免如下错误

Premature end of script headers: wsgi.py
您需要从httpd.conf中删除cgi配置

AddHandler cgi-script .py  

您使用的是virtualenv还是全局python?您还可以发布您的.wsgi conf文件吗?这是导入设置模块的地方,问题可能是项目文件树的一个表示形式。我真的在寻找一般的疑难解答技巧,而不是问题的解决方案。给男人一条鱼…我用的是mod_python,不是WSGI。我也没有使用virtualenv。我的os.path.exists(“/home/mysite/prg/mysite/mysite\u django/settings.py”)为true,但我仍然无法导入mysite\u django。设置:没有名为mysite\u django的模块。设置帮助。。。
import os
import sys                                              #new
path = '/var/www/html/mysite'                           #new
if path not in sys.path:                                #new
    sys.path.append(path)                               #new

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite.settings")
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
Premature end of script headers: wsgi.py
AddHandler cgi-script .py