flask使用了blueprint或者restful情况下,scoped_session 创建一个线程安全的会话 with app.app_context()的平替

我的项目后端是python-flask框架,使用了flask-restx来开发RESTful API。
前几天遇到一个问题:想要在restx的某个命名空间中调用多线程来批量提交数据库。但是报错了,显示需要使用 with app.app_context() 来设置一个上下文。
但是我的项目采用工程模式创建flask app实例。并且在使用了 flask-restx 命名空间的情况下,如果模块需要调用with app.app_context()是无法实现的。会触发循环导入。

推荐使用SQLAlchemy的 scoped_session 来创建一个线程安全的会话:

from sqlalchemy import create_engine
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy.orm import DeclarativeBase, sessionmaker, scoped_session

# 定义基类
class Base(DeclarativeBase):
    pass

# 创建数据库引擎
engine = create_engine() # 数据库的连接配置

# 创建线程安全的会话
db_session = scoped_session(sessionmaker(bind=engine))

# 初始化 SQLAlchemy
db 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值