Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/67.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python sqlalchemy mysql连接在flask api上未关闭_Python_Mysql_Flask_Sqlalchemy_Database Connection - Fatal编程技术网

Python sqlalchemy mysql连接在flask api上未关闭

Python sqlalchemy mysql连接在flask api上未关闭,python,mysql,flask,sqlalchemy,database-connection,Python,Mysql,Flask,Sqlalchemy,Database Connection,我在flask中编写了一个api。它使用sqlalchemy来处理mysql数据库。我不使用flask sqlalchemy,因为我不喜欢模块强制您进入特定模式以声明模型的方式 我遇到数据库连接未关闭的问题。表示连接的对象超出范围,因此我假设它正在被垃圾收集。我还显式地在会话上调用close()。尽管存在这些事实,但在api调用返回响应后,连接仍然保持打开状态 py:这是我用于会话的包装器 class SqlSession: def __init__(self, conn=Constan

我在flask中编写了一个api。它使用sqlalchemy来处理mysql数据库。我不使用flask sqlalchemy,因为我不喜欢模块强制您进入特定模式以声明模型的方式

我遇到数据库连接未关闭的问题。表示连接的对象超出范围,因此我假设它正在被垃圾收集。我还显式地在会话上调用close()。尽管存在这些事实,但在api调用返回响应后,连接仍然保持打开状态

py:这是我用于会话的包装器

class SqlSession:
    def __init__(self, conn=Constants.Sql):
        self.db = SqlSession.createEngine(conn)

        Session = sessionmaker(bind=self.db)
        self.session = Session()
    @staticmethod
    def createEngine(conn):
        return create_engine(conn.URI.format(user=conn.USER, password=conn.PASS, host=conn.HOST, port=conn.PORT, database=conn.DATABASE, poolclass=NullPool))

    def close(self):
        self.session.close()
flaskroutes.py:下面是一个flask应用程序实例化和使用包装器对象的示例。请注意,它在api调用范围内开始实例化它,然后在结束时关闭会话,并且可能在返回响应后进行垃圾收集

def commands(self, deviceId):
    sqlSession = SqlSession(self.sessionType) <---

    commandsQueued = getCommands()
    jsonCommands = []
    for command in commandsQueued:
     jsonCommand = command.returnJsonObject()
     jsonCommands.append(jsonCommand)
     sqlSession.session.delete(command)
    sqlSession.session.commit()
    resp = jsonify({'commands': jsonCommands})
    sqlSession.close() <---  
    resp.status_code = 200
    return resp
def命令(self、deviceId):

sqlSession=sqlSession(self.sessionType)我最后使用了这篇SO帖子的建议:

我强烈建议有这个问题的人阅读这篇文章。基本上,我为close方法添加了dispose()调用。这样做会导致整个连接被破坏,而关闭只会将连接返回到可用池(但保持打开状态)


整个过程让我有点困惑,但至少现在我对连接池有了更多的了解

只是想让你知道你在三年后帮了我很大的忙,就像@SamHollenbach一样,这在几年后帮了我
def close(self):
    self.session.close()
    self.db.dispose()