SQLAlchemy连接池默认行为导致Flask应用卡住,因Flask不自动关闭session,QueuePool在高并发下易耗尽连接或泄漏,造成idle in transaction堆积;需在teardown_appcontext中调用db.session.close()并合理配置pool_pre_ping、pool_recycle等参数。SQLAlchemy连接池默认行为为什么会让Flask应用卡住Flask本身不管理数据库连接生命周期,而SQLAlchemy默认的QueuePool在高并发下容易耗尽连接、或因连接泄漏导致后续请求阻塞在pool.get()上。典型现象是:接口响应突然变慢,日志里没报错,但psql -c "SELECT * FROM pg_stat_activity;"能看到大量idle in transaction状态的连接。根本原因是:Flask每次请求结束时不会自动关闭SQLAlchemy session,更不会归还底层DBAPI连接——除非你显式调用db.session.remove()或配置了正确的作用域。别依赖scoped_session的线程本地自动清理:Flask多线程/多进程模型下它不可靠,异步视图(如async def)中完全失效SQLALCHEMY_ENGINE_OPTIONS = {"pool_pre_ping": True}必须开,否则失效连接会卡在池里直到超时(默认30分钟)避免在全局作用域直接用db.session.query(...)——这会绑定到第一个请求的线程上下文,后续请求可能复用错误连接Flask中正确的session生命周期控制方式不是靠装饰器或中间件“统一关闭”,而是让每个请求只用一个session,并在请求周期结束时强制清理。SQLAlchemy 1.4+推荐用db.session.close()而非remove(),因为后者会销毁整个scoped_session实例。在@app.teardown_appcontext里调用db.session.close(),不是teardown_request(后者不覆盖CLI命令和后台任务)如果用了flask-sqlalchemy,确保SQLALCHEMY_TRACK_MODIFICATIONS=False,否则每次模型变动都触发额外查询,拖慢连接释放手动创建session时(比如离线脚本),务必用with db.session.begin():,而不是裸db.session.add()——否则异常时连接不会自动回滚归还示例:立即学习“Python免费学习笔记(深入)”; Convai Technologies Inc. 对话式 AI API,用于设计游戏和支持端到端的语音交互
Python Flask项目中如何管理数据库连接_使用SQLAlchemy连接池管理