Django:Whitenoise 在调试错误的情况下无法在生产中工作

Posted

技术标签:

【中文标题】Django:Whitenoise 在调试错误的情况下无法在生产中工作【英文标题】:Django: Whitenoise not working in production with debug false 【发布时间】:2020-01-16 06:48:26 【问题描述】:

我有一个带有白噪声的 Django 应用程序,用于静态文件。但是当我使用 Google Lighthouse 测试应用程序时,我被要求为我的静态 .js 和 .css 文件启用文本压缩。

我阅读了很多相关的帖子,但找不到答案。

我还按照 Heroku 的指南来实施它。 https://devcenter.heroku.com/articles/django-assets

设置

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

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',
    'django_user_agents.middleware.UserAgentMiddleware',
]

STATIC_ROOT = os.path.join(BASE_DIR, 'static')
STATIC_URL = '/static/'
MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, "media")

STATICFILES_DIRS = (
    os.path.join(BASE_DIR, 'static'),
)

STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'

我也使用 Dropbox 存储媒体文件,但它似乎不是问题,我删除它我仍然有静态文件问题。

DEFAULT_FILE_STORAGE = 'storages.backends.dropbox.DropBoxStorage'

要求

我确实在要求中包含了最新的 Whitenoise,并且在部署 Heroku 时没有出现错误:

whitenoise==4.1.2

在 Lighthouse 中进行测试时,要求压缩此文件。它们来自静态文件夹,我知道当我运行 Manage.py collectstatic 时它们应该被压缩

…css/bootstrap.min.css(afternoon-wildwood-39943.herokuapp.com)
…js/jquery-3.2.1.min.js(afternoon-wildwood-39943.herokuapp.com)
…js/bootstrap-table.min.js(afternoon-wildwood-39943.herokuapp.com)
…css/Fran%20Style.css(afternoon-wildwood-39943.herokuapp.com)
…js/popper.min.js(afternoon-wildwood-39943.herokuapp.com)

调试设置

我读到也许应该将 debug 设置为 False 以使其工作。上面的示例是使用 Debug = True 完成的。

DEBUG = bool(os.environ.get('DJANGO_DEBUG', True))

在这种情况下,应用程序运行良好,但如果将调试设置为 False,我会收到错误 500 页面。

我在 Heroku 托管。您可以尝试以下示例:http://afternoon-wildwood-39943.herokuapp.com/website/

有什么线索吗?提前致谢!

【问题讨论】:

【参考方案1】:

感谢 Heroku 的支持,我找到了解决此问题的方法。现在我的应用程序在调试设置为 false 的情况下工作正常,并且我得到了由 whitenoise 提供的 Gzip 静态文件。

静态收集

首先你应该在将应用程序部署到 Heroku 之前运行 collectstatic 命令,我一直认为这是部署后要做的事情。

过程文件

您应该在 procfile 中添加以下代码行:

release: python manage.py migrate

【讨论】:

我不知道这对您有何帮助,因为在将应用程序部署到 heroku 时,它会在部署之前自动运行 COLLECTSTATIC 命令。 仍然感谢迁移命令。我不知道“发布:”。

以上是关于Django:Whitenoise 在调试错误的情况下无法在生产中工作的主要内容,如果未能解决你的问题,请参考以下文章

如何调试使用 whitenoise、gunicorn 和 heroku 服务的 django 静态文件?

如何调试带有whitenoise,gunicorn和heroku的Django静态文件?

使用 Django 在 Heroku 上接收带有图像的特定页面的服务器错误 500(由 WhiteNoise 提供静态服务)

使用 WhiteNoise 在生产模式下将 django 部署到 Elastic Beanstalk

gzip 在带有 Whitenoise 的 Django 中不起作用

如何在 Django 中为 WhiteNoise 5.1.0 设置 wsgi.py 文件?