Джанго терпит неудачу, иногда очень странное поведение - PullRequest
0 голосов
/ 15 декабря 2009

У меня ужасные проблемы с тем, что django по-разному реагирует на одни и те же запросы без видимой причины.

Иногда я обновляюсь и вижу ошибку, затем я обновляюсь и она исчезает, иногда шаблон жалуется на пропущенное значение, а затем снова в порядке, снова без объяснения причин.

Иногда он извлекает графику с рабочего сервера, иногда с сервера разработки.

Хуже всего, иногда, очень часто, все выглядит и загружается нормально, но запрос возвращает 0 попаданий, даже если второй набор запросов, основанный на том же запросе, загружается нормально, как один и тот же запрос может завершиться неудачей 1008 * внутри того же запроса? Для этого последнего у меня есть теория, что он вообще не получает переменную набора запросов из представления.

Мне не хватает ключевых слов для поиска этой проблемы, я на пороге портирования проекта на php, потому что, по крайней мере, он всегда отображается одинаково.

Проект устанавливается как wsgi с использованием apache2, да, каждый раз, когда я обновляюсь, я проверяю touch wsgi.py, сценарий WSGI.

Пожалуйста, помогите .

Конфигурация Apache vhost:

<VirtualHost *>
    ServerAdmin admin@example.com
    ServerName example.com
    ServerAlias www.example.com

    DocumentRoot /home/self/example.com
    <Directory />
        Options FollowSymLinks
        AllowOverride None
    </Directory>
    <Directory /home/self/example.com>
        Options Indexes FollowSymLinks MultiViews
        AllowOverride None
        Order allow,deny
        allow from all
    </Directory>

    Alias /media/ /home/self/projects/django/myapp/media/
    <Directory /home/self/projects/django/myapp/media/>
        Order deny,allow
        Allow from all
    </Directory>
    WSGIScriptAlias / /home/self/projects/django/myapp/wsgi.py
    <Directory /home/self/projects/django/myapp/>
        Order allow,deny
        Allow from all
    </Directory>
    ErrorLog /home/self/example.com/error.log
    LogLevel warn
    CustomLog /home/self/example.com/access.log combined
    ServerSignature Off
</VirtualHost>

Это wsgi.py

import os
import sys
sys.path.append('/home/self/projects/django')
sys.path.append('/home/self/projects/django/myapp')
os.environ['DJANGO_SETTINGS_MODULE'] = 'myapp.settings'

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

и settings.py

#!/usr/bin/python
# -*- coding: utf-8 -*-

# Django settings for myapp project.
import os
PROJECT_DIR = os.path.dirname(os.path.abspath(__file__))

DEBUG = True
TEMPLATE_DEBUG = DEBUG

ADMINS = (
    # ('My self', 'self@example.com'),
)

MANAGERS = ADMINS

DATABASE_ENGINE = 'sqlite3'                           # 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
DATABASE_NAME = os.path.join(PROJECT_DIR, 'myapp.db') # Or path to database file if using sqlite3.
DATABASE_USER = ''             # Not used with sqlite3.
DATABASE_PASSWORD = ''         # 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 = 'America/Tegucigalpa'

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

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 = ''

# 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 = ''

# 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 = 'http://media.example.com/media/'

AUTH_PROFILE_MODULE = "myapp.userprofile"
LOGIN_URL = "/login"

# Make this unique, and don't share it with anybody.
SECRET_KEY = '1(!u3tvq^=x)y@kny&^eg&uevo6&y%k-wgl$q$-sl_0+s%3g^5'

# 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',
    'pagination.middleware.PaginationMiddleware',
)

ROOT_URLCONF = 'myapp.urls'

TEMPLATE_DIRS = (
    os.path.join(PROJECT_DIR, 'templates'),
    # 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.
)

TEMPLATE_CONTEXT_PROCESSORS = (
    "django.core.context_processors.auth",
    "django.core.context_processors.debug",
    "django.core.context_processors.i18n",
    "django.core.context_processors.media",
    "django.core.context_processors.request",
)

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'myapp',
    'pagination',
)

UPDATE:

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

Это звучит как проблема с кэшированием, но я не занимаюсь кэшированием самостоятельно, также я всегда делаю touch wsgi.py, чтобы обновить скрипт WSGI, и это все, что мне нужно для обновления приложения.

Ответы [ 3 ]

2 голосов
/ 15 декабря 2009

Сохраняете ли вы состояние в глобальных переменных? Если это так, ответ будет отличаться в зависимости от предыдущих запросов к тому же процессу.

Будьте уверены, Django надежно используется тысячами сайтов каждый день. Ваша проблема не свойственна Джанго.

1 голос
/ 15 декабря 2009

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

Когда это усложняется, иногда лучшим решением является использование метода разработки KISS. Напишите небольшие кусочки кода и проверьте их, чтобы убедиться, что они работают так, как задумано.

Если вы беспокоитесь о WSGI, сначала запустите небольшой простой проект. Затем представьте слои сложности, чтобы попытаться определить, где проблема начинает возникать; предоставляя отличный способ устранить ошибку.

Используйте модуль pytest unittest.TestCase и doctests, чтобы помочь вам с Python стороной проверки ошибок.

Всего наилучшего! :)

0 голосов
/ 15 декабря 2009

Вам нужно показать код ваших просмотров, если вы считаете, что проблема в этом. В противном случае мы можем только догадываться, в чем может быть проблема.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...