Django Whitenoise在非调试模式下出现500服务器错误

15

我正在本地使用Django。为了提供静态文件,我同时使用了WhiteNoise。当DEBUG = True时,所有静态文件都可以正确提供。但是当我将DEBUG = False并设置ALLOWED_HOSTS = ['*']时,出现500服务器错误。但是Admin网站可以无误加载。当我注释掉STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'时,就不会出现500错误。

我按照http://whitenoise.evans.io/en/stable/django.html中的文档连接了Whitenoise。我没有对wsgi.py文件进行任何更改。我运行了python manage.py collecststatic,没有出现任何错误。

下面是settings.py

import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

SECRET_KEY = 'fdft&b(xb*!qq3ghjkjhg6789ih8ik!w10$0uscxcpqpmz'
DEBUG = False

ALLOWED_HOSTS = ['*']

INSTALLED_APPS = [
'whitenoise.runserver_nostatic', #Disable Djangos static file server during DEVELOPMENT
'gep_app.apps.GepAppConfig',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]

MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'whitenoise.middleware.WhiteNoiseMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

ROOT_URLCONF = 'gep_project.urls'

TEMPLATES = [
{
    'BACKEND': 'django.template.backends.django.DjangoTemplates',
    'DIRS': [],
    'APP_DIRS': True,
    'OPTIONS': {
        'context_processors': [
            'django.template.context_processors.debug',
            'django.template.context_processors.request',
            'django.contrib.auth.context_processors.auth',
            'django.contrib.messages.context_processors.messages',
        ],
    },
},
]

WSGI_APPLICATION = 'gep_project.wsgi.application'


DATABASES = {
'default': {
    'ENGINE': 'django.db.backends.postgresql_psycopg2',
    'NAME': '*************',
    'USER': '*****',
    'PASSWORD': '********',
    'HOST': '*****',
    'PORT': '5432',
}
}

 # User model
 AUTH_USER_MODEL = 'gep_app.User'

 # Login URL
 LOGIN_URL = 'login'

 # Login redirect
 LOGIN_REDIRECT_URL = 'home'

 # Logout redirect
 LOGOUT_REDIRECT_URL = 'login'

 #Authentication backends
 AUTHENTICATION_BACKENDS = (
    'django.contrib.auth.backends.ModelBackend',
)

LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True

STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'

你的服务器日志显示了什么错误? - markwalker_
1
@markwalker_ 没有实际的错误。Django 只是返回 500。由于注释 STATICFILE_STORAGE 可以给出正确的输出,因此错误必须与 whitenoise 有关。 - Devika Sudheer
@markwalker_ [2018年12月20日 05:46:03] "GET /accounts/login/ HTTP/1.1" 500 27 这是在控制台中打印的。 - Devika Sudheer
3个回答

27

我遇到了一个类似的错误,日志显示 ValueError: 缺少静态文件清单条目...

按照 whitenoise文档中的这个部分 的描述,将 settings.py 中的 STATICFILES_STORAGE 从:
'whitenoise.storage.CompressedManifestStaticFilesStorage'
改为:
'whitenoise.storage.CompressedStaticFilesStorage' 解决了这个问题。

此外,由于 SECRET_KEY 已经公开,您可能还需要更改它。


两年后仍然相关。这帮助我解决了一个类似的问题。谢谢。 - Slyme
http://whitenoise.evans.io/en/stable/django.html#storage-troubleshoot - Antonio Romero Oca
我花了一整天的时间搜索,但是没有找到解决方案。现在终于有东西起作用了! - c.dipu0

3

快速解决方案的更改:

STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'

to:

STATICFILES_STORAGE = 'whitenoise.storage.CompressedStaticFilesStorage'

但是!它会生成没有唯一块键的静态文件,无法在客户端浏览器中正确更新(例如style.343a1fa2da70.css),客户端不刷新网站缓存后将看不到更改。 WhiteNoise仅在Django存储周围添加了一个薄包装以添加压缩支持,并且由于压缩代码非常简单,通常不会引起问题。所以你需要:

  1. 返回STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
  2. 手动清除staticfiles文件夹
  3. 通过py manage.py collectstatic --noinput刷新静态资源
  4. 享受吧!

2
大多数上述答案都可以让您的应用程序重新运行,但是如果您想利用静态文件缓存策略,则可能无法实现与预期相同的结果。
您收到内部服务器错误的原因是,在添加Whitenoise之前,您已经运行了python manage.py collectstatic,默认使用了STATICFILES_STORAGE='django.contrib.staticfiles.storage.StaticFilesStorage'
因此,要保持您的设置为STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage',只需再次运行python manage.py collectstatic即可。
Django文档here应该会给您更多的信息。

在第二次运行 python manage.py collectstatic 之前,您可能需要删除/清除生成的静态文件文件夹。 - RKatana

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接