SqlAlchmy Session的线程安全问题

SqlAlchemy的Session默认不是线程安全的,官方提供了两种解决方案,包括使用Contextual/Thread-local Sessions和避免全局Session。在使用flask-sqlalchemy时,发现其创建了一个预配置的scoped session,通过源码分析确认db.session是线程安全的,对SqlAlchemy进行了封装,增加了便捷性。
摘要由CSDN通过智能技术生成

代码码到一半,突然想到,Session是否是线程安全的?于是上官方文档,答案是否!

那问题来了,怎么破?因为它会牵涉到多线程情况下,调用rollback导致的不可预期影响。

官网给了两个方案:

  1. 使用 Contextual/Thread-local Sessions
  2. 不用全局的,而是采用函数间传递的session变量

明显,第一种方式对现在代码的改动最小,扩展性也更好。因为使用的flask-sqlalchemy,于是参考在线文档 ,发现table的定义与flask-sqlalchemy quickstart的定义不一致。文档里面有一句有趣的话

a preconfigured scoped session called session

那是否意味着 flask-sqlalchemy 对 sqlachemy 封装之后,将session做了多线程支持的封装?看源码!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值