Gunicorn 抛出 KeyError 导致内部服务器错误
Gunicorn throws KeyError resulting in Internal Server Error
在我的 Flask 应用程序中,我有
app = Flask(__name__)
app.config['MAX_CONTENT_LENGTH'] = 10 * 1024 * 1024
class StreamConsumingMiddleware(object):
def __init__(self, app):
self.app = app
def __call__(self, environ, start_response):
stream = LimitedStream(environ['wsgi.input'], int(environ['CONTENT_LENGTH'] or 0))
environ['wsgi.input'] = stream
app_iter = self.app(environ, start_response)
try:
stream.exhaust()
for event in app_iter:
yield event
finally:
if hasattr(app_iter, 'close'):
app_iter.close()
app.wsgi_app = StreamConsumingMiddleware(app.wsgi_app)
当我简单地 运行 使用 python app.py
的应用程序时,它按预期工作。但是,使用 Gunicorn gunicorn app:app
启动时,应用程序启动正常,但尝试加载任何页面都会导致 500,并抛出 KeyError
[2015-11-08 17:36:53 -0500] [15848] [ERROR] Error handling request
Traceback (most recent call last):
File "[...]/venv/lib/python2.7/site-packages/gunicorn/workers/sync.py", line 130, in handle
self.handle_request(listener, req, client, addr)
File "[...]/venv/lib/python2.7/site-packages/gunicorn/workers/sync.py", line 176, in handle_request
for item in respiter:
File "[...]/app.py", line 33, in __call__
stream = LimitedStream(environ['wsgi.input'], int(environ['CONTENT_LENGTH'] or 0))
KeyError: 'CONTENT_LENGTH'
有什么想法吗?
您正在访问一个不存在的密钥。 Python 词典提供了一个 get
方法来帮助解决这个问题
int(os.environ.get('CONTENT_LENGTH', 0))
如果密钥存在,这将 return os.environ['CONTENT_LENGTH']
的值,如果不存在,则为 0。
在我的 Flask 应用程序中,我有
app = Flask(__name__)
app.config['MAX_CONTENT_LENGTH'] = 10 * 1024 * 1024
class StreamConsumingMiddleware(object):
def __init__(self, app):
self.app = app
def __call__(self, environ, start_response):
stream = LimitedStream(environ['wsgi.input'], int(environ['CONTENT_LENGTH'] or 0))
environ['wsgi.input'] = stream
app_iter = self.app(environ, start_response)
try:
stream.exhaust()
for event in app_iter:
yield event
finally:
if hasattr(app_iter, 'close'):
app_iter.close()
app.wsgi_app = StreamConsumingMiddleware(app.wsgi_app)
当我简单地 运行 使用 python app.py
的应用程序时,它按预期工作。但是,使用 Gunicorn gunicorn app:app
启动时,应用程序启动正常,但尝试加载任何页面都会导致 500,并抛出 KeyError
[2015-11-08 17:36:53 -0500] [15848] [ERROR] Error handling request
Traceback (most recent call last):
File "[...]/venv/lib/python2.7/site-packages/gunicorn/workers/sync.py", line 130, in handle
self.handle_request(listener, req, client, addr)
File "[...]/venv/lib/python2.7/site-packages/gunicorn/workers/sync.py", line 176, in handle_request
for item in respiter:
File "[...]/app.py", line 33, in __call__
stream = LimitedStream(environ['wsgi.input'], int(environ['CONTENT_LENGTH'] or 0))
KeyError: 'CONTENT_LENGTH'
有什么想法吗?
您正在访问一个不存在的密钥。 Python 词典提供了一个 get
方法来帮助解决这个问题
int(os.environ.get('CONTENT_LENGTH', 0))
如果密钥存在,这将 return os.environ['CONTENT_LENGTH']
的值,如果不存在,则为 0。