I've been working on a new dev platform using nginx/gunicorn and Flask for my application.
Ops-wise, everything works fine - the issue I'm having is with debugging the Flask layer. When there's an error in my code, I just get a straight 500 error returned to the browser and nothing shows up on the console or in my logs.
I've tried many different configs/options.. I guess I must be missing something obvious.
My gunicorn.conf:
import os
bind = '127.0.0.1:8002'
workers = 3
backlog = 2048
worker_class = "sync"
debug = True
proc_name = 'gunicorn.proc'
pidfile = '/tmp/gunicorn.pid'
logfile = '/var/log/gunicorn/debug.log'
loglevel = 'debug'
An example of some Flask code that borks- testserver.py:
from flask import Flask
from flask import render_template_string
from werkzeug.contrib.fixers import ProxyFix
app = Flask(__name__)
@app.route('/')
def index():
n = 1/0
return "DIV/0 worked!"
And finally, the command to run the flask app in gunicorn:
gunicorn -c gunicorn.conf.py testserver:app
Thanks y'all
For Heroku users, there is a simpler solution than creating a bin/web script like suggested by Nick.
Instead of
foreman start
, just useforeman run python app.py
if you want to debug your application in development.The acception solution doesn't work for me.
Gunicorn is a pre-forking environment and apparently the Flask debugger doesn't work in a forking environment.
Even if you set
app.debug = True
, you will still only get an empty page with the message Internal Server Error if you run withgunicorn testserver:app
. The best you can do with gunicorn is to run it withgunicorn --debug testserver:app
. That gives you the trace in addition to the Internal Server Error message. However, this is just the same text trace that you see in the terminal and not the Flask debugger.Adding the
if __name__ ...
section to the testserver.py and runningpython testserver.py
to start the server in development gets you the Flask debugger. In other words, don't use gunicorn in development if you want the Flask debugger.Tip for Heroku users:
Personally I still like to use
foreman start
, instead ofpython testserver.py
since it sets up all the env variables for me. To get this to work:Contents of
Procfile
Contents of
bin/web
, file is relative to project rootIn development, create a
.env
file relative to project root with the following contents (docs here)Also, dont forget to change the
app.config['DEBUG']...
line intestserver.py
to something that won't run Flask in debug mode in production.The Flask config is entirely separate from gunicorn's. Following the Flask documentation on config files, a good solution would be change my source to this:
And in config.py:
Try setting the debug flag on the run command like so
and keep the
DEBUG = True
in your Flask application. There must be a reason why your debug option is not being applied from the config file but for now the above note should get you going.I had similiar problem when running flask under gunicorn I didn't see stacktraces in browser (had to look at logs every time). Setting DEBUG, FLASK_DEBUG, or anything mentioned on this page didn't work. Finally I did this:
Note evalex is disabled because interactive debbugging won't work with forking (gunicorn).