Переход на производственную среду сломал мое приложение - PullRequest
0 голосов
/ 25 января 2012

Я только что развернул свое приложение на Dreamhost, и оно перестало работать при загрузке файлов.Пассажир просто выдаёт 500 внутренних ошибок.Он работает на моей настройке разработки.
Мой пассажирский файл выглядит так:

import sys, os
sys.path.append(os.getcwd())
sys.path.append(os.path.join(os.getcwd(), '/photosoc'))

os.environ['DJANGO_SETTINGS_MODULE'] = "photosoc.settings"
import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()

Я получаю стандартную ошибку 404 (отладка все еще включена).Мне пришлось изменить файл URL-адреса с:

from django.conf.urls.defaults import patterns, include, url
from competition.models import Image
from competition import *
from django.contrib import admin
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.conf import settings

# Uncomment the next two lines to enable the admin:
from django.contrib import admin
admin.autodiscover()
admin.site.register(Image)

urlpatterns = patterns('',
    # Examples:
    # url(r'^$', 'photosoc.views.home', name='home'),
    # url(r'^photosoc/', include('photosoc.foo.urls')),

    # Uncomment the admin/doc line below to enable admin documentation:
    # url(r'^admin/doc/', include('django.contrib.admindocs.urls')),

    # Uncomment the next line to enable the admin:
    url(r'^admin/', include(admin.site.urls)),
#   url(r'^image/$', 'competition.views.index'),
    url(r'^image/uploadImage', 'competition.views.uploadImage'),
    url(r'^image/uploadCompleted', 'competition.views.uploadCompleted'),
    url(r'^image/uploadFailed', 'competition.views.uploadFailed'),
)

urlpatterns += patterns('',
    (r'^media/(?P<path>.*)$', 'django.views.static.serve', {'document_root': settings.MEDIA_ROOT}))

на следующее:

from django.conf.urls.defaults import patterns, include, url
from competition.models import Image
from competition import *
from django.contrib import admin
from django.conf import settings

# Uncomment the next two lines to enable the admin:
from django.contrib import admin
admin.autodiscover()
admin.site.register(Image)

urlpatterns = patterns('',
    # Examples:
    # url(r'^$', 'photosoc.views.home', name='home'),
    # url(r'^photosoc/', include('photosoc.foo.urls')),

    # Uncomment the admin/doc line below to enable admin documentation:
    # url(r'^admin/doc/', include('django.contrib.admindocs.urls')),

    # Uncomment the next line to enable the admin:
    url(r'^admin/', include(admin.site.urls)),
#   url(r'^image/$', 'competition.views.index'),
    url(r'^image/uploadImage', 'competition.views.uploadImage'),
    url(r'^image/uploadCompleted', 'competition.views.uploadCompleted'),
    url(r'^image/uploadFailed', 'competition.views.uploadFailed'),
)

Это единственное изменение, которое я внес в приложение после перехода с разработкик производству.Так что еще могло пойти не так?

Ответы [ 2 ]

0 голосов
/ 25 января 2012

Точно ли совпадают ваши настройки в классах промежуточного программного обеспечения, которые вы импортируете?Дважды проверьте, что они одинаковы.

Связанный:

ModSecurity: Фильтр вывода: не удалось прочитать корзину (rc 104): сброс соединения по пиру

0 голосов
/ 25 января 2012

У вас могут быть проблемы с разрешениями.

Кажется, вы пишете файлы изображений.Имеет ли процесс, на котором работает Django, разрешение на запись файлов?Когда вы запускаете Django локально с ./manage.py runserver, Django получает разрешения пользователя, который запускается из командной строки, но в типичной производственной среде вы будете работать с разрешениями пользователя Apache.Этот пользователь может не иметь прав для записи этих файлов изображений.Вы можете попытаться временно жестко запрограммировать каталог записи в / tmp, чтобы увидеть, имеет ли это значение.

Конечно, вам действительно нужно увидеть трассировку стека 500 ошибок, чтобы узнать, что происходит.

...