【问题标题】:Error while deploying Django on Apache在 Apache 上部署 Django 时出错
【发布时间】:2010-10-15 00:11:21
【问题描述】:

我有一个小型 Django 网站,我试图在 Apache 2.2 HTTP-Server 上运行。 该应用程序使用“python manage.py runserver”运行良好。

Django 版本:1.0.2 最终版
Python:2.5
操作系统:Windows 2000

我没有完成documentation 中描述的步骤,经过一番摆弄,在我的 httpd.conf 中得出以下内容。

<Location "/therap/">
SetHandler python-program
PythonHandler django.core.handlers.modpython
SetEnv DJANGO_SETTINGS_MODULE settings
PythonOption django.root /therap
PythonDebug On
PythonPath "['D:/therap/therap'] + sys.path"
</Location>

MaxRequestsPerChild 1

D:\therap\therap 在我的 manage.py 所在的地方。

当我尝试在浏览器中打开时,我看到 Django 使用的样式出现错误(与白色背景上的黑色 courier 不同。)

ImportError at /

No module named therap.urls

Request Method: GET
Request URL:    http://****:8080/
Exception Type: ImportError
Exception Value:   

No module named therap.urls

Exception Location: C:\python25\lib\site-packages\django\core\urlresolvers.py in _get_urlconf_module, line 200
Python Executable:  C:\Programme\Apache Software Foundation\Apache2.2\bin\httpd.exe
Python Version:     2.5.1
Python Path:        ['D:/therap/therap', 'C:\\WINNT\\system32\\python25.zip', 'C:\\Python25\\Lib', 'C:\\Python25\\DLLs', 'C:\\Python25\\Lib\\lib-tk', 'C:\\Programme\\Apache Software Foundation\\Apache2.2', 'C:\\Programme\\Apache Software Foundation\\Apache2.2\\bin', 'C:\\Python25', 'C:\\Python25\\lib\\site-packages', 'C:\\Python25\\lib\\site-packages\\pyserial-2.2', 'C:\\Python25\\lib\\site-packages\\win32', 'C:\\Python25\\lib\\site-packages\\win32\\lib', 'C:\\Python25\\lib\\site-packages\\Pythonwin', 'C:\\Python25\\lib\\site-packages\\wx-2.8-msw-unicode']
Server time:        Mo, 23 Mär 2009 16:27:03 +0100

在 D:\therap\therap 中有一个 urls.py。 但是在我的大部分代码所在的 D:\therap\therap\main 中没有。

然后我尝试使用父文件夹

<Location "/therap/">
    SetHandler python-program
    PythonHandler django.core.handlers.modpython
    SetEnv DJANGO_SETTINGS_MODULE therap.settings
    PythonOption django.root /therap
    PythonDebug On
    PythonPath "['D:/therap'] + sys.path"

</Location>

MaxRequestsPerChild 1

这给了我一个不同的错误:

MOD_PYTHON ERROR

ProcessId:      2424
Interpreter:    '***'

ServerName:     '****'
DocumentRoot:   'C:/Programme/Apache Software Foundation/Apache2.2/htdocs'

URI:            '/therap/'
Location:       '/therap/'
Directory:      None
Filename:       'C:/Programme/Apache Software Foundation/Apache2.2/htdocs/therap'
PathInfo:       '/'

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

Traceback (most recent call last):

  File "C:\Python25\Lib\site-packages\mod_python\importer.py", line 1537, in HandlerDispatch
    default=default_handler, arg=req, silent=hlist.silent)

  File "C:\Python25\Lib\site-packages\mod_python\importer.py", line 1229, in _process_target
    result = _execute_target(config, req, object, arg)

  File "C:\Python25\Lib\site-packages\mod_python\importer.py", line 1128, in _execute_target
    result = object(arg)

  File "C:\Python25\lib\site-packages\django\core\handlers\modpython.py", line 228, in handler
    return ModPythonHandler()(req)

  File "C:\Python25\lib\site-packages\django\core\handlers\modpython.py", line 201, in __call__
    response = self.get_response(request)

  File "C:\python25\Lib\site-packages\django\core\handlers\base.py", line 67, in get_response
    response = middleware_method(request)

  File "C:\python25\Lib\site-packages\django\middleware\locale.py", line 17, in process_request
    translation.activate(language)

  File "C:\python25\Lib\site-packages\django\utils\translation\__init__.py", line 73, in activate
    return real_activate(language)

  File "C:\python25\Lib\site-packages\django\utils\translation\trans_real.py", line 209, in activate
    _active[currentThread()] = translation(language)

  File "C:\python25\Lib\site-packages\django\utils\translation\trans_real.py", line 198, in translation
    default_translation = _fetch(settings.LANGUAGE_CODE)

  File "C:\python25\Lib\site-packages\django\utils\translation\trans_real.py", line 183, in _fetch
    app = __import__(appname, {}, {}, [])

ImportError: No module named main

我确实使用了国际化模块,但我现在不明白为什么它会导致问题。

“main”是唯一的 Django 应用程序的名称(包含视图、模型、表单等)。完整路径是 D:\therap\therap\main。

我把__init__.py-files 从主文件夹放到d:\therap.

现在我不知道我还能做什么。有什么想法吗?

【问题讨论】:

    标签: python windows django apache mod-python


    【解决方案1】:

    问题是您正在导入您的应用程序(“main”),就好像它直接位于 Python 路径上一样,而您的 URLconf(“therap.urls”)就好像它位于 Python 上的“therap”模块中一样小路。这只有在“D:/therap”和“D:/therap/therap”都在 Python 路径上时才有效(runserver 会自动为您“让事情变得简单”;尽管它最终只是延迟了混乱,直到部署时间)。您可以在 Apache 配置中使用以下行来模拟 runserver 的行为:

    PythonPath "['D:/therap', 'D:/therap/therap'] + sys.path"
    

    标准化你的引用可能更有意义,这样你的 Python 路径只需要包含一个或另一个。通常的方式(至少我看到的更经常引用的方式)是将“D:\therap”放在 Python 路径上,并将您的应用程序限定为“therap.main”,而不仅仅是“main”。就我个人而言,我采取了相反的方法,它工作得很好:将“D:\therap\therap”放在你的 Python 路径上,并将 ROOT_URLCONF 设置为“urls”而不是“therap.urls”。这样做的好处是,如果将来您想让您的“主”应用程序可重用并将其移出特定项目,您对它的引用不会与项目名称“therap”相关联(尽管应用程序名为“ main”,这听起来不像您在考虑可重用应用程序)。

    【讨论】:

    • 非常感谢。好像和你描述的一样。但是我的应用程序仍然没有运行。它说它找不到我的一张表(可能全部,使用 sqlite3)。如果我自己无法解决,我可能会发布一个后续问题。
    猜你喜欢
    • 2016-02-26
    • 2014-07-31
    • 1970-01-01
    • 2020-01-07
    • 1970-01-01
    • 2015-01-27
    • 2014-12-02
    • 2015-04-28
    • 2012-08-08
    相关资源
    最近更新 更多