python - Flask RESTful API : Issue with db connection pool

标签 python azure flask flask-sqlalchemy flask-restful

我正在尝试使用 Flask 框架创建 REST 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:x@x:1433/x?driver=SQL Server"

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()
        e = create_engine(conn_string)
        conn = e.connect()

        stat = """
        select x from report 
        """

        query = conn.execute(stat)

        json_dict = []


        for i in query.cursor.fetchall():
                res = {'x': i[0], 'xx': i[1]}
                json_dict.append(res)


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


api.add_resource(Report, '/report')

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

问题是,当我仅调用此 API 一天左右时,我会得到结果,此后我将停止获取结果,除非重新启动我的脚本(有时甚至是我的虚拟机),然后再次得到结果。我认为数据库连接池或其他问题存在一些问题,但我正在关闭连接并处理它。我不知道为什么 API 只在一段时间内给我结果,因为我必须每天重新启动我的虚拟机。有什么想法吗?

最佳答案

根据我的经验,该问题是由编写 create_engine(conn_string) 代码在类 Report 中创建数据库池引起的,以便始终执行数据库的创建和销毁操作适合每个安静要求的游泳池。这不是使用 SQLAlchemy ORM 的正确方法,并且会导致与数据库连接相关的 IO 资源冲突,请参阅下面的 engine.dispose() 函数说明 http://docs.sqlalchemy.org/en/rel_1_0/core/connections.html#sqlalchemy.engine.Engine :

enter image description here

要解决此问题,您只需将 e = create_engine(conn_string) 移至代码下面的 conn_string = "mssql+pyodbc://x:x@x: 1433/x?driver=SQL Server" 并删除类 Report 中的代码 e.dispose(),请参见下文。

conn_string = "mssql+pyodbc://x:x@x:1433/x?driver=SQL Server"
e = create_engine(conn_string) # To here

def get(delf)函数中:

args = parser.parse_args()
# Move: e = create_engine(conn_string)
conn = e.connect()

conn.close()
# Remove: e.dispose()
return jsonify(results=json_dict)

关于python - Flask RESTful API : Issue with db connection pool,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33819747/

相关文章:

python - Octave/Matlab 与 Scipy 中的周期图

azure - 找出 HPC 命令行实用程序的 (Azure) OAuth2 授权流程

Heroku Redis 上的 SSL 认证验证失败

python - 张量板中没有标量数据

python - 如何从 json 文件中提取一些文本而不加载它?

azure - 在 Azure 部署组中对服务器进行分组的最佳策略是什么

azure - 如何取消管道——没有可用的取消按钮

Python Flask - json 和 html 404 错误

python - 如何在 Flask 中创建友好的 url?

python - 添加两个 DataFrame 并对列进行排序(前两个除外)