首页 > 数据库 >flask多线程下数据库操作(简单示例)

flask多线程下数据库操作(简单示例)

时间:2024-09-03 16:56:53浏览次数:7  
标签:users 示例 flask db add session user print 多线程

前言

背景:开了两个线程操作数据库插入但是获取不到db的信息,自己摸索的方法不一定是最佳的,有更好的可以评论或私信,感谢大佬

话不多说,直接上代码

	# 模型里面的多线程新增操作
    @staticmethod
    def add_users_by_thread(username, password, session):
        user = User(username=username, password=password)
        session.add(user)
@task_blueprint.route('/add_users_by_thread', methods=['POST'])
def add_users_by_thread():
    print(f"db: {db}")
    print(f"db.engine: {db.engine}")
    print("--------------------------------------------------")
    print("Submitting tasks to thread pool")
    with current_app.app_context():# 这里手动推入上下文,在线程提交之前
        executor.submit(add_users_one(db))# 这里需要将db传进去,不然无法获取到session,主要是在方法里面打印db无法获取到主线程的连接信息
    with current_app.app_context():
        executor.submit(add_users_two(db))
    print("Tasks submitted")
    return jsonify({'message': 'users added!'})

# add_users_one和add_users_two是类似的操作
def add_users_one(db):
    print("add_users_one started!")
    try:
        session_factory = sessionmaker(bind=db.engine)
        Session = scoped_session(session_factory)
        session = Session()
        for user_data in users_to_insert:
            print(f"add_users_one processing: {user_data['username']}, {user_data['password']}")
            User.add_users_by_thread(user_data['username'], user_data['password'], session)
            print("add_users_one done!")
            time.sleep(1)
        session.commit()
        print("add_users_one committed successfully")
    except Exception as e:
        session.rollback()
        print(f"Error in add_users_one: {e}")
    finally:
        session.close()
        print("Session closed")

这里之前试了在add_users_one里面开启上下文,程序不报错,但是数据不会写入,然后将上下文在线程提交之前手动推入就有报错了,然后排查是获取不到db信息,在线程提交之后不管怎么操作都拿不到db信息,所以在提交的同时将db传递到方法里面,这样就拿到了db信息

简单解释一下add_users_one过程

  • 使用 sessionmaker 创建一个会话工厂 session_factory,并将数据库引擎 db.engine 绑定到该工厂
  • 使用 scoped_session 包装会话工厂,确保在多线程环境中每个线程都有自己的会话实例
  • 通过 Session() 实例化一个会话对象 session
  • 遍历 users_to_insert 列表中的每个用户数据 user_data
  • 调用 User.add_users_by_thread 方法将用户数据插入到数据库中,传入用户名、密码和会话对象 session
  • 使用 time.sleep(1) 暂停 1 秒,通常用于防止过快的数据库操作或模拟延迟
  • 如果在 try 块中发生异常,捕获异常并回滚事务,以确保数据库状态不会受到未成功操作的影响
  • 在 finally 块中,无论是否发生异常,都关闭会话,释放资源

标签:users,示例,flask,db,add,session,user,print,多线程
From: https://blog.csdn.net/weixin_42695345/article/details/141865523

相关文章

  • flask简单自学(docker形式)
    前言参考详细地址:https://juejin.cn/post/6970663530215407652,感谢作者,作者主页直达正文flask的dockerfile(python版本3.8.6)注意:在docker里面运行python需要指定host和port:app.run(host=‘0.0.0.0’,port=5000,debug=True)requirements.txt依赖项内容:Flaskgunicorn......
  • 4个成功的事务性邮件示例
    如何确定您正在充分利用交易邮件?您可能已经了解了一些关于交易邮件的基础知识以及一些确保邮件合规和良好执行的一般最佳实践。但是,您是否能够轻松地利用多种数据源个性化您的交易邮件,例如提取客户特有的忠诚积分数量?您是否能够战略性地安排其他通信与您的交易流程同步,例如仅......
  • (3-5)绘制散点图和折线图:Flask+pygal+SQLite实现数据分析
    3.5 Flask+pygal+SQLite实现数据分析在本节的内容中,将使用Flask+pygal+SQLite3实现数据分析功能。将需要分析的数据保存在SQLite3数据库中,然后在FlaskWeb网页中使用库pygal绘制出对应的统计图。3.5.1 创建数据库首先使用PyCharm创建一个FlaskWeb项目,然后通过文件model......
  • https 服务示例 go-gin框架 支持ssl/tls,
    本文为演示采用自签名证书一.生成证书通过openssl工具生成证书1.1安装opensslmacos通过brew安装brewinstallopenssl1.2生成跟证书私钥opensslgenrsa-outca.key40961.3准备配置文件vimca.conf内容如下   [req]   default_bits      =4096   distin......
  • 为什么多线程会带来性能问题?
    为什么多线程会带来性能问题?什么是性能问题在上一篇中,我们已经学习了多线程带来的线程安全问题,但对于多线程而言,它不仅可能会带来线程安全问题,还有可能会带来性能问题,也许你会奇怪,我们使用多线程的最大目的不就是为了提高性能吗?让多个线程同时工作,加快程序运行速度,为什么反而会带来......
  • 基于python+flask框架的企业员工献血管理平台(开题+程序+论文) 计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着企业社会责任意识的增强和公众对健康公益事业的日益关注,企业员工献血已成为企业履行社会责任、展现人文关怀的重要方式之一。然而,传统......
  • 基于python+flask框架的绿洲便利店商品售卖系统(开题+程序+论文) 计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着现代都市生活节奏的加快,消费者对便捷购物服务的需求日益增长。便利店作为零售业态的重要组成部分,以其商品种类丰富、位置便利、服务快......
  • 基于python+flask框架的图书管理系统(开题+程序+论文) 计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着信息技术的飞速发展和数字化时代的到来,图书馆作为知识传播与存储的重要机构,其管理方式正经历着深刻的变革。传统的图书管理模式依赖人......
  • 从零开始:用Flask和UIAutomation构建RPA微信自动群发工具
    文章目录前言一、环境搭建系统要求flask安装uiautomation安装二、群发功能的实现要导入的包1.构建WxOperation类2.搜寻被发送人3.发送文本4.发送文件5.接收消息三、构建后端服务要导入的包文件框架1.index.html文件2.app.py四、成果展示总结前言在这个数字化......
  • 配置 expect 免交互自动化脚本 2个示例
    文章目录示例1:实现密码输入错误的提示示例2:用免交互的方式给硬盘分区、格式化、挂载示例1:实现密码输入错误的提示在expect脚本中,可以通过捕捉密码错误的输出信息来提示用户。比如:expect{"password"{send"$password\r"}"Permissiondenied"{send_......