解决flask的502错误:upstream prematurely closed connection while reading response header from upstream

我在使用 tiangolo/uwsgi-nginx-flask 部署flask应用的时候,常常运行一下子就出现502错误,从新启动容器后,就恢复。react

且常常会出现数据更新后,刷新结果不一致。nginx

docker做者的github中也有人遇到相似问题。https://github.com/tiangolo/uwsgi-nginx-flask-docker/issues/92git

查询容器的日志能够看到upstream prematurely closed connection while reading response header from upstreamgithub

说是链接没有释放。现将解决方案记录一下:sql

http://flask.pocoo.org/docs/1.0/patterns/sqlalchemy/docker

在flask文档中有介绍使用一个装饰器来进行session释放。flask

from yourapplication.database import db_session

@app.teardown_appcontext
def shutdown_session(exception=None):
    db_session.remove()

 

具体适用方法以下:session

一:app

from flask import Flask
from yourapplication.database import db_session
app = Flask(name)
@app.teardown_appcontext
def shutdown_session(exception=None):
  db_session.remove()

二:spa

from flask import Flask
from yourapplication.database import db_session
def create_app():
    app = Flask(name)
    return app
app = create_app()

@app.teardown_appcontext
def shutdown_session(exception=None):
    db_session.remove()
相关文章
相关标签/搜索