当我将 Debug - False 设置为 True 时,Django Heroku 服务器错误 (500) 工作正常

Pek*_*sio 12 django heroku

我知道对此有很多问题,但说实话,大多数问题都没有得到解答,或者解决方案不起作用。

我有“简单”的问题。当我将 Debug 设置为 False 并将其推送到 heroku 时,我收到“服务器错误 (500)”。我读了这些主题:

当 Debug = False 时,Heroku 服务器错误 (500),whitenoise 找不到 style.css

每当 django 中的 debug=False 时,Heroku 都会给出服务器错误 (500),而当 debug=True 时则不会出现错误

https://www.reddit.com/r/djangolearning/comments/acj65x/why_am_i_getting_a_500_server_error_when/

https://teamtreehouse.com/community/heroku-bad-request-500

我尝试了他们的解决方案,但仍然不起作用。我没有测试过但应该有帮助的唯一解决方案是消除白噪声。这对我来说有点“不行”。

对于这个错误我该怎么办?

谢谢并干杯!

编辑:

这是我的日志。我试图注释掉白噪音,但没有帮助。

我正在查看我的代码,但没有任何对“favicon.ico”的引用。另外,我尝试运行collectstatic,因为我发现了一些与之相关的主题,但它对我不起作用。

首先它问我:

You have requested to collect static files at the destination
location as specified in your settings:

    /app/staticfiles
Run Code Online (Sandbox Code Playgroud)

然后我得到了错误:

FileNotFoundError: [Errno 2] No such file or directory: '/app/static'
Run Code Online (Sandbox Code Playgroud)

这很奇怪,因为首先它向我确认我将这个文件夹从 static 覆盖到 staticfiles 。在我的主目录中,我有文件夹“staticfiles”。在我的应用程序文件夹中,我有文件夹“static”。关闭调试后一切正常。

    2020-05-19T05:15:40.192943+00:00 heroku[router]: at=info method=GET path="/favicon.ico" host=robotbuilder.herokuapp.com request_id=eeaf4fd1-b73b-4e84-aacd-7e701d3e8932 fwd="83.26.255.146" dyno=web.1 connect=1ms service=3ms status=404 bytes=388 protocol=http

2020-05-19T05:15:39.991705+00:00 app[web.1]: [2020-05-19 05:15:39 +0000] [11] [ERROR] Error handling request /

2020-05-19T05:15:39.991725+00:00 app[web.1]: Traceback (most recent call last):

2020-05-19T05:15:39.991726+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/gunicorn/workers/sync.py", line 134, in handle

2020-05-19T05:15:39.991734+00:00 app[web.1]:     self.handle_request(listener, req, client, addr)

2020-05-19T05:15:39.991734+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/gunicorn/workers/sync.py", line 175, in handle_request

2020-05-19T05:15:39.991735+00:00 app[web.1]:     respiter = self.wsgi(environ, resp.start_response)

2020-05-19T05:15:39.991735+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/wsgi.py", line 133, in __call__

2020-05-19T05:15:39.991735+00:00 app[web.1]:     response = self.get_response(request)

2020-05-19T05:15:39.991736+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/base.py", line 75, in get_response

2020-05-19T05:15:39.991736+00:00 app[web.1]:     response = self._middleware_chain(request)

2020-05-19T05:15:39.991736+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991737+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991739+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991740+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991741+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991741+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991741+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/whitenoise/middleware.py", line 58, in __call__

2020-05-19T05:15:39.991742+00:00 app[web.1]:     response = self.get_response(request)

2020-05-19T05:15:39.991746+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991747+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991747+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991747+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991747+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991748+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991748+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/utils/deprecation.py", line 94, in __call__

2020-05-19T05:15:39.991748+00:00 app[web.1]:     response = response or self.get_response(request)

2020-05-19T05:15:39.991748+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991749+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991749+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991749+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991750+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991750+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991750+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/utils/deprecation.py", line 94, in __call__

2020-05-19T05:15:39.991750+00:00 app[web.1]:     response = response or self.get_response(request)

2020-05-19T05:15:39.991751+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991751+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991751+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991752+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991752+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991752+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991752+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/utils/deprecation.py", line 94, in __call__

2020-05-19T05:15:39.991753+00:00 app[web.1]:     response = response or self.get_response(request)

2020-05-19T05:15:39.991753+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991753+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991753+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991754+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991754+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991755+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991763+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/utils/deprecation.py", line 94, in __call__

2020-05-19T05:15:39.991763+00:00 app[web.1]:     response = response or self.get_response(request)

2020-05-19T05:15:39.991763+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991764+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991764+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991764+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991764+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991765+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991765+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/utils/deprecation.py", line 94, in __call__

2020-05-19T05:15:39.991765+00:00 app[web.1]:     response = response or self.get_response(request)

2020-05-19T05:15:39.991765+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991766+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991766+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991766+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991766+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991767+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991767+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/utils/deprecation.py", line 94, in __call__

2020-05-19T05:15:39.991767+00:00 app[web.1]:     response = response or self.get_response(request)

2020-05-19T05:15:39.991767+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991768+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991768+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991768+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991768+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991769+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991769+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/utils/deprecation.py", line 94, in __call__

2020-05-19T05:15:39.991769+00:00 app[web.1]:     response = response or self.get_response(request)

2020-05-19T05:15:39.991769+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991770+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991770+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991770+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991771+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991771+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991771+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/whitenoise/middleware.py", line 58, in __call__

2020-05-19T05:15:39.991771+00:00 app[web.1]:     response = self.get_response(request)

2020-05-19T05:15:39.991772+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 36, in inner

2020-05-19T05:15:39.991772+00:00 app[web.1]:     response = response_for_exception(request, exc)

2020-05-19T05:15:39.991772+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 90, in response_for_exception

2020-05-19T05:15:39.991772+00:00 app[web.1]:     response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())

2020-05-19T05:15:39.991780+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/exception.py", line 34, in inner

2020-05-19T05:15:39.991781+00:00 app[web.1]:     response = get_response(request)

2020-05-19T05:15:39.991781+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/base.py", line 115, in _get_response

2020-05-19T05:15:39.991782+00:00 app[web.1]:     response = self.process_exception_by_middleware(e, request)

2020-05-19T05:15:39.991782+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/core/handlers/base.py", line 113, in _get_response

2020-05-19T05:15:39.991782+00:00 app[web.1]:     response = wrapped_callback(request, *callback_args, **callback_kwargs)

2020-05-19T05:15:39.991783+00:00 app[web.1]:   File "/app/builder/views.py", line 8, in home

2020-05-19T05:15:39.991783+00:00 app[web.1]:     return render(request, "builder/home.html")

2020-05-19T05:15:39.991783+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/shortcuts.py", line 19, in render

2020-05-19T05:15:39.991784+00:00 app[web.1]:     content = loader.render_to_string(template_name, context, request, using=using)

2020-05-19T05:15:39.991790+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/loader.py", line 62, in render_to_string

2020-05-19T05:15:39.991790+00:00 app[web.1]:     return template.render(context, request)

2020-05-19T05:15:39.991791+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/backends/django.py", line 61, in render

2020-05-19T05:15:39.991791+00:00 app[web.1]:     return self.template.render(context)

2020-05-19T05:15:39.991791+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/base.py", line 171, in render

2020-05-19T05:15:39.991792+00:00 app[web.1]:     return self._render(context)

2020-05-19T05:15:39.991792+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/base.py", line 163, in _render

2020-05-19T05:15:39.991792+00:00 app[web.1]:     return self.nodelist.render(context)

2020-05-19T05:15:39.991792+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/base.py", line 936, in render

2020-05-19T05:15:39.991793+00:00 app[web.1]:     bit = node.render_annotated(context)

2020-05-19T05:15:39.991793+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/base.py", line 903, in render_annotated

2020-05-19T05:15:39.991798+00:00 app[web.1]:     return self.render(context)

2020-05-19T05:15:39.991798+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/loader_tags.py", line 150, in render

2020-05-19T05:15:39.991798+00:00 app[web.1]:     return compiled_parent._render(context)

2020-05-19T05:15:39.991799+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/base.py", line 163, in _render

2020-05-19T05:15:39.991799+00:00 app[web.1]:     return self.nodelist.render(context)

2020-05-19T05:15:39.991799+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/base.py", line 936, in render

2020-05-19T05:15:39.991799+00:00 app[web.1]:     bit = node.render_annotated(context)

2020-05-19T05:15:39.991800+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/template/base.py", line 903, in render_annotated

2020-05-19T05:15:39.991800+00:00 app[web.1]:     return self.render(context)

2020-05-19T05:15:39.991800+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/templatetags/static.py", line 106, in render

2020-05-19T05:15:39.991800+00:00 app[web.1]:     url = self.url(context)

2020-05-19T05:15:39.991804+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/templatetags/static.py", line 103, in url

2020-05-19T05:15:39.991804+00:00 app[web.1]:     return self.handle_simple(path)

2020-05-19T05:15:39.991804+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/templatetags/static.py", line 118, in handle_simple

2020-05-19T05:15:39.991805+00:00 app[web.1]:     return staticfiles_storage.url(path)

2020-05-19T05:15:39.991805+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/staticfiles/storage.py", line 153, in url

2020-05-19T05:15:39.991805+00:00 app[web.1]:     return self._url(self.stored_name, name, force)

2020-05-19T05:15:39.991806+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/staticfiles/storage.py", line 132, in _url

2020-05-19T05:15:39.991806+00:00 app[web.1]:     hashed_name = hashed_name_func(*args)

2020-05-19T05:15:39.991806+00:00 app[web.1]:   File "/app/.heroku/python/lib/python3.6/site-packages/django/contrib/staticfiles/storage.py", line 423, in stored_name

2020-05-19T05:15:39.991806+00:00 app[web.1]:     raise ValueError("Missing staticfiles manifest entry for '%s'" % clean_name)

2020-05-19T05:15:39.991807+00:00 app[web.1]: ValueError: Missing staticfiles manifest entry for 'builder/logo.png'

2020-05-19T05:15:39.992027+00:00 app[web.1]: 10.95.191.28 - - [19/May/2020:05:15:39 +0000] "GET / HTTP/1.1" 500 0 "-" "-"

2020-05-19T05:15:40.192825+00:00 app[web.1]: 10.95.191.28 - - [19/May/2020:05:15:40 +0000] "GET /favicon.ico HTTP/1.1" 404 179 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:76.0) Gecko/20100101 Firefox/76.0"

2020-05-19T05:15:39.996509+00:00 heroku[router]: at=info method=GET path="/" host=robotbuilder.herokuapp.com request_id=de877e93-558a-40ab-bf11-b6de261cb707 fwd="83.26.255.146" dyno=web.1 connect=1ms service=57ms status=500 bytes=244 protocol=http
Run Code Online (Sandbox Code Playgroud)

编辑2:

    import os
import django_heroku
from decouple import config
import dj_database_url

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))


# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/3.0/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = config('SECRET_KEY')

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = False

ALLOWED_HOSTS = []


# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'builder',
]

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',

Pek*_*sio 8

我想我明白了。该解决方案正在发挥作用。但我认为这也很奇怪。如果有人能评论为什么会这样,我将不胜感激。

你可以留下白噪音,你可以稍微整理一下静态文件目录。让它看起来像这样:

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


STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
Run Code Online (Sandbox Code Playgroud)

但我认为没有必要。(最好将“静态”文件夹保留在主项目文件夹中)。

但最大的解决办法是(在 django 3 上工作):

你需要跑

python manage.py collectstatic
Run Code Online (Sandbox Code Playgroud)

本地!然后提交给heroku。然后,一切正常,调试设置为 False。我尝试仅使用 .keep 文件保留collectstatic。我尝试仅提交 .json,希望它能用新的collectstatic 文件重新填充。但不是。仅当我在本地运行collectstatic然后将所有内容提交到heroku时它才起作用。

如果有人对这个问题有更多的了解并且可以向我解释,我将非常感激。

同时,我希望其他人也能从这个解决方案中受益。

我找到了这个问题的答案 - ValueError: Missing staticfiles Manifest Entry for 'favicon.ico'。非常感谢 emazzotta,我也不必摆脱白噪声,它在 django3 中工作。

  • 你救了我的命。我花了两周时间与 django 和 heroku 进行斗争。你的帖子顺利解决了一切!谢谢。我使用一个名为“设置”的文件夹,其中包含两个配置文件。因此,唯一的区别是 BASE_DIR 其他一切都相同。 (2认同)

小智 6

通过键入此内容heroku logs --tail -a your_herokuapp_namehttps://dashboard.heroku.com/apps/your_herokuapp_name/logs来调试您的 django 应用程序。

在此之前,将其添加到您的settings.py

 # Debugging in heroku live
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'verbose': {
            'format': ('%(asctime)s [%(process)d] [%(levelname)s] ' +
                       'pathname=%(pathname)s lineno=%(lineno)s ' +
                       'funcname=%(funcName)s %(message)s'),
            'datefmt': '%Y-%m-%d %H:%M:%S'
        },
        'simple': {
            'format': '%(levelname)s %(message)s'
        }
    },
    'handlers': {
        'null': {
            'level': 'DEBUG',
            'class': 'logging.NullHandler',
        },
        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
            'formatter': 'verbose'
        }
    },
    'loggers': {
        'testlogger': {
            'handlers': ['console'],
            'level': 'INFO',
        }
    }
}

DEBUG_PROPAGATE_EXCEPTIONS = True
COMPRESS_ENABLED = os.environ.get('COMPRESS_ENABLED', False)
Run Code Online (Sandbox Code Playgroud)

这将在 heroku 日志中显示错误debug=False

堆栈溢出问题 [来源]