我正在尝试部署一个 django 应用程序,它基本上是托管在我的服务器中的readthedocs实例。根据文档建议,它配置为 gunicorn + nginx,但我发现了一个小问题:无论我在 URL 中输入什么,应用程序都会始终返回 404 错误。我尝试了一些实验,我发现如果我设置DEBUG = True
,settings.py
那么一切正常。我找不到任何给我相关信息的日志文件,到目前为止我搜索的所有内容都表明问题通常出在静态文件上,而不是模块上。我的问题是整个模块。
如何检查应用程序出了什么问题?我应该从哪里开始?
这是相关的配置文件:
import os
import djcelery
djcelery.setup_loader()
_ = gettext = lambda s: s
DEBUG = False
TEMPLATE_DEBUG = DEBUG
TASTYPIE_FULL_DEBUG = True
PRODUCTION_DOMAIN = 'readthedocs.org'
USE_SUBDOMAIN = False
ADMINS = (
('Charlie Leifer', 'coleifer@gmail.com'),
('Eric Holscher', 'eric@ericholscher.com'),
)
MANAGERS = ADMINS
SITE_ROOT = '/'.join(os.path.dirname(__file__).split('/')[0:-2])
DOCROOT = os.path.join(SITE_ROOT, 'user_builds')
UPLOAD_ROOT = os.path.join(SITE_ROOT, 'user_uploads')
CNAME_ROOT = os.path.join(SITE_ROOT, 'cnames')
LOGS_ROOT = os.path.join(SITE_ROOT, 'logs')
MEDIA_ROOT = '%s/media/' % (SITE_ROOT)
MEDIA_URL = '/media/'
ADMIN_MEDIA_PREFIX = '/media/admin/'
# For 1.4
STATIC_ROOT = os.path.join(SITE_ROOT, 'media/static/')
STATIC_URL = '/static/'
#STATICFILES_DIRS = ()
#STATICFILES_FINDERS = ()
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.dummy.DummyCache',
'PREFIX': 'docs',
}
}
CACHE_MIDDLEWARE_SECONDS = 60
LOGIN_REDIRECT_URL = '/dashboard/'
FORCE_WWW = False
#APPEND_SLASH = False
TIME_ZONE = 'America/Chicago'
LANGUAGE_CODE = 'en-us'
LANGUAGES = (
('en', gettext('English')),
('nb', gettext('Norwegian')),
('fr', gettext('French')),
)
USE_I18N = True
USE_L10N = True
SITE_ID = 1
SECRET_KEY = 'asciidick'
ACCOUNT_ACTIVATION_DAYS = 7
TEMPLATE_LOADERS = (
'django.template.loaders.filesystem.Loader',
'django.template.loaders.app_directories.Loader',
)
MIDDLEWARE_CLASSES = (
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.locale.LocaleMiddleware',
'django.middleware.common.CommonMiddleware',
'djangosecure.middleware.SecurityMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'pagination.middleware.PaginationMiddleware',
# Hack
'core.underscore_middleware.UnderscoreMiddleware',
'core.middleware.SubdomainMiddleware',
#'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware',
)
ROOT_URLCONF = 'urls'
TEMPLATE_DIRS = (
'%s/readthedocs/templates/' % SITE_ROOT,
)
TEMPLATE_CONTEXT_PROCESSORS = (
"django.contrib.auth.context_processors.auth",
"django.core.context_processors.debug",
"django.core.context_processors.i18n",
"django.core.context_processors.media",
"django.core.context_processors.request",
"core.context_processors.readthedocs_processor",
)
INSTALLED_APPS = [
'django.contrib.auth',
'django.contrib.admin',
'django.contrib.contenttypes',
'django.contrib.markup',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.staticfiles',
# third party apps
'pagination',
'registration',
'profiles',
'taggit',
'south',
'basic.flagging',
'djangosecure',
'guardian',
'django_gravatar',
# Celery bits
'djcelery',
'celery_haystack',
# daniellindsleyrocksdahouse
'haystack',
'tastypie',
# our apps
'projects',
'builds',
'core',
'rtd_tests',
]
if DEBUG:
INSTALLED_APPS.append('django_extensions')
#CARROT_BACKEND = "ghettoq.taproot.Database"
CELERY_ALWAYS_EAGER = True
CELERYD_TASK_TIME_LIMIT = 60*60 #60 minutes
CELERY_SEND_TASK_ERROR_EMAILS = True
CELERY_ROUTES = {
'celery_haystack.tasks.CeleryHaystackSignalHandler': {
'queue': 'celery_haystack',
},
'projects.tasks.fileify': {
'queue': 'celery_haystack',
},
}
DEFAULT_FROM_EMAIL = "no-reply@readthedocs.org"
SESSION_COOKIE_DOMAIN = 'readthedocs.org'
HAYSTACK_CONNECTIONS = {
'default': {
'ENGINE': 'haystack.backends.simple_backend.SimpleEngine',
},
}
AUTH_PROFILE_MODULE = "core.UserProfile"
SOUTH_TESTS_MIGRATE = False
ABSOLUTE_URL_OVERRIDES = {
'auth.user': lambda o: "/profiles/%s/" % o.username
}
INTERNAL_IPS = ('127.0.0.1',)
IMPORT_EXTERNAL_DATA = True
backup_count = 1000
if DEBUG:
backup_count = 2
# Guardian Settings
GUARDIAN_RAISE_403 = True
ANONYMOUS_USER_ID = -1
# RTD Settings
REPO_LOCK_SECONDS = 30
ALLOW_PRIVATE_REPOS = False
LOGGING = {
'version': 1,
'disable_existing_loggers': True,
'formatters': {
'standard': {
'format' : "[%(asctime)s] %(levelname)s [%(name)s:%(lineno)s] %(message)s",
'datefmt' : "%d/%b/%Y %H:%M:%S"
},
},
'handlers': {
'null': {
'level':'DEBUG',
'class':'django.utils.log.NullHandler',
},
'logfile': {
'level':'DEBUG',
'class':'logging.handlers.RotatingFileHandler',
'filename': os.path.join(LOGS_ROOT, "rtd.log"),
'maxBytes': 50000,
'backupCount': backup_count,
'formatter': 'standard',
},
'errorlog': {
'level':'DEBUG',
'class':'logging.handlers.RotatingFileHandler',
'filename': os.path.join(LOGS_ROOT, "rtd.log"),
'maxBytes': 50000,
'backupCount': backup_count,
'formatter': 'standard',
},
'db': {
'level':'DEBUG',
'class':'logging.handlers.RotatingFileHandler',
'filename': os.path.join(LOGS_ROOT, "db.log"),
'maxBytes': 50000,
'backupCount': backup_count,
'formatter': 'standard',
},
'mail_admins': {
'level': 'ERROR',
'class': 'django.utils.log.AdminEmailHandler',
},
'console':{
'level':'DEBUG',
'class':'logging.StreamHandler',
'formatter': 'standard'
},
},
'loggers': {
'django': {
'handlers':['console', 'errorlog'],
'propagate': True,
'level':'WARN',
},
'django.db.backends': {
'handlers': ['db'],
'level': 'DEBUG',
'propagate': False,
},
'django.request': {
'handlers': ['mail_admins'],
'level': 'ERROR',
'propagate': False,
},
#Default handler for everything that we're doing. Hopefully this doesn't double-print
#the Django things as well. Not 100% sure how logging works :)
'': {
'handlers': ['console', 'logfile'],
'level': 'DEBUG',
},
}
}