Я пытался записать приложение в django, работающем - но он не работает вообще. Я продолжал работать в течение некоторого времени также - и это работает над dev-сервером отлично. Но я не могу вставить производственный ENV (апач).
Мое название проекта является apstat, и название приложения является основным.
Я пытаюсь получить доступ к нему как после
Блок цитирования http://hostname/apstat
Но это показывает следующую ошибку:
MOD_PYTHON ERROR
ProcessId: 6002
Interpreter: 'domU-12-31-39-06-DD-F4.compute-1.internal'
ServerName: 'domU-12-31-39-06-DD-F4.compute-1.internal'
DocumentRoot: '/home/ubuntu/server/'
URI: '/apstat/'
Location: '/apstat'
Directory: None
Filename: '/home/ubuntu/server/apstat/'
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/lib/pymodules/python2.6/django/core/handlers/modpython.py", line 228, in handler
return ModPythonHandler()(req)
File "/usr/lib/pymodules/python2.6/django/core/handlers/modpython.py", line 201, in __call__
response = self.get_response(request)
File "/usr/lib/pymodules/python2.6/django/core/handlers/base.py", line 134, in get_response
return self.handle_uncaught_exception(request, resolver, exc_info)
File "/usr/lib/pymodules/python2.6/django/core/handlers/base.py", line 154, in handle_uncaught_exception
return debug.technical_500_response(request, *exc_info)
File "/usr/lib/pymodules/python2.6/django/views/debug.py", line 40, in technical_500_response
html = reporter.get_traceback_html()
File "/usr/lib/pymodules/python2.6/django/views/debug.py", line 114, in get_traceback_html
return t.render(c)
File "/usr/lib/pymodules/python2.6/django/template/__init__.py", line 178, in render
return self.nodelist.render(context)
File "/usr/lib/pymodules/python2.6/django/template/__init__.py", line 779, in render
bits.append(self.render_node(node, context))
File "/usr/lib/pymodules/python2.6/django/template/debug.py", line 81, in render_node
raise wrapped
TemplateSyntaxError: Caught an exception while rendering: No module named basic
Original Traceback (most recent call last):
File "/usr/lib/pymodules/python2.6/django/template/debug.py", line 71, in render_node
result = node.render(context)
File "/usr/lib/pymodules/python2.6/django/template/debug.py", line 87, in render
output = force_unicode(self.filter_expression.resolve(context))
File "/usr/lib/pymodules/python2.6/django/template/__init__.py", line 572, in resolve
new_obj = func(obj, *arg_vals)
File "/usr/lib/pymodules/python2.6/django/template/defaultfilters.py", line 687, in date
return format(value, arg)
File "/usr/lib/pymodules/python2.6/django/utils/dateformat.py", line 269, in format
return df.format(format_string)
File "/usr/lib/pymodules/python2.6/django/utils/dateformat.py", line 30, in format
pieces.append(force_unicode(getattr(self, piece)()))
File "/usr/lib/pymodules/python2.6/django/utils/dateformat.py", line 175, in r
return self.format('D, j M Y H:i:s O')
File "/usr/lib/pymodules/python2.6/django/utils/dateformat.py", line 30, in format
pieces.append(force_unicode(getattr(self, piece)()))
File "/usr/lib/pymodules/python2.6/django/utils/encoding.py", line 71, in force_unicode
s = unicode(s)
File "/usr/lib/pymodules/python2.6/django/utils/functional.py", line 201, in __unicode_cast
return self.__func(*self.__args, **self.__kw)
File "/usr/lib/pymodules/python2.6/django/utils/translation/__init__.py", line 62, in ugettext
return real_ugettext(message)
File "/usr/lib/pymodules/python2.6/django/utils/translation/trans_real.py", line 286, in ugettext
return do_translate(message, 'ugettext')
File "/usr/lib/pymodules/python2.6/django/utils/translation/trans_real.py", line 276, in do_translate
_default = translation(settings.LANGUAGE_CODE)
File "/usr/lib/pymodules/python2.6/django/utils/translation/trans_real.py", line 194, in translation
default_translation = _fetch(settings.LANGUAGE_CODE)
File "/usr/lib/pymodules/python2.6/django/utils/translation/trans_real.py", line 180, in _fetch
app = import_module(appname)
File "/usr/lib/pymodules/python2.6/django/utils/importlib.py", line 35, in import_module
__import__(name)
ImportError: No module named basic
Мой settings.py следующие:
INSTALLED_APPS = (
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'apstat.basic',
'django.contrib.admin',
)
Если я удаляю apstat.basic, он проходит, но это не решение. Это - что-то, что я делаю в апаче?
Мой апач - настройки -
ServerAdmin webmaster@localhost
DocumentRoot /home/ubuntu/server/
Options None
AllowOverride None
AllowOverride None
Order allow,deny
allow from all
SetHandler python-program
PythonHandler django.core.handlers.modpython
SetEnv DJANGO_SETTINGS_MODULE apstat.settings
PythonOption django.root /home/ubuntu/server/
PythonDebug On
PythonPath "['/home/ubuntu/server/'] + sys.path"
Я теперь сидел больше дня на этом. Если бы кто-то может выручить меня, это было бы очень хорошо.
Обычно каталог проекта добавляется в sys.path
, а затем имя приложения используется непосредственно в INSTALLED_APPS
и в импорте в других приложениях. Попробуйте.
Необходимо убедиться, что проект находится в вашем PYTHONPATH
. Возможно, попробуйте вывести переменную sys.path
в верхней части файла настроек:
import sys
print sys.path
Если это не работает с mod_python
, попробуйте записать ее в файл:
import sys
file('/tmp/mysyspath.txt', 'w').write(repr(sys.path))
Но даже если это сработает, вот короткое предупреждение:
В сообществе django не рекомендуется использовать mod_python
. Он больше не поддерживается его создателями и никогда не был лучшим решением для развертывания вашего проекта django. Пожалуйста, попробуйте mod_wsgi
, если он доступен для вас на вашем сервере.