我有一个在烧瓶里写的api。它使用sqlalchemy来处理mysql数据库。我不使用flask sqlalchemy,因为我不喜欢模块强制您进入特定模式来声明模型的方式。
我的数据库连接无法关闭。表示连接的对象超出了范围,因此我假设它是垃圾回收的。我还在会话中显式调用close()。尽管存在这些事实,但是在api调用返回其响应之后,连接会保持打开状态很长时间。
这是我在会话中使用的包装器。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
我希望在http响应完成后立即清除连接,但连接最终会处于“睡眠”状态(在mysql命令行界面“show processlist”中查看时)。