Flask API:如何清除数据库连接池?

时间:2015-12-08 21:04:48

标签: python azure flask sqlalchemy flask-restful

我几天来一直在努力解决这个问题,但似乎无法找到任何解决方案。我正在尝试使用Flask框架创建REST APIendpoint。问题是API会在一段时间内给出正确的结果,并且随着时间的推移,它会停止接收任何请求。我不知道它为什么突然这样做。我最好的猜测是它的数据库连接池没有被清除。正如您在下面的代码中看到的,我正在正确关闭数据库连接,但我仍然面临这个问题。请帮忙!

from flask import Flask, jsonify
from flask_restful import Resource, Api
from flask_restful import reqparse
from sqlalchemy import create_engine
from flask.ext.httpauth import HTTPBasicAuth
from flask.ext.cors import CORS

conn_string = "mssql+pyodbc://x"
e = create_engine(conn_string)

auth = HTTPBasicAuth()

@auth.get_password
def get_password(username):
    if username == 'x':
        return 'x'
    return None

app = Flask(__name__)
cors = CORS(app)
api = Api(app)

class Report(Resource):
    decorators = [auth.login_required]

    def get(self):
        parser = reqparse.RequestParser()
        parser.add_argument('start', type = str)
        parser.add_argument('end', type = str)
        args = parser.parse_args()

        conn = e.connect()

        stat = """
        select a, b from report where c < ? and d > ?
        """

        query = conn.execute(stat, [args['start'], args['end']])

        json_dict = []

        for i in query.cursor.fetchall():


            res = {'aa': i[0], 'bb':i[1]}
            json_dict.append(res)

        conn.close()
        return jsonify(results=json_dict)

api.add_resource(Report, '/report')

if __name__ == '__main__':
    app.run(host='0.0.0.0')

1 个答案:

答案 0 :(得分:0)

我根据您的代码构建了一个快速测试项目,连接到Azure SQL数据库,查询在本地运行的简单句子select * from (values (1), (2), (3), (4), (5)) numbers(number)。并通过node.js每秒请求此API 10次。经过几个小时的测试,它仍然运行良好。甚至我使用NullPool禁用了池,它显示在SQLalchemy guide

创建SQLalchemy连接引擎时,您可以尝试放大pool sizeset Pool Recycle。如果是数据库连接池问题。

但根据我的测试结果,您可以监控应用程序以进行调试。 要调试在本地运行的刻录应用程序,您可以使用logging模块,有关详细信息,请参阅http://flask.pocoo.org/docs/0.10/errorhandling/