当前位置: 首页 > news >正文

Python 异步编程:Sqlalchemy 异步实现方式

SQLAlchemy 是 Python 中最流行的数据库工具之一,在新版本中引入了对异步操作的支持。这为使用异步框架(如 FastAPI)开发应用程序带来了极大的便利。在这篇文章中,简单介绍下 SQLAlchemy 是如何利用 Greenlet 实现异步操作的。

什么是 Greenlet?

Greenlet 是一个轻量级的第三方协程库,最初由 PyPy 项目开发。它允许在单个操作系统线程内执行多个任务(协程),这些任务可以相互间切换,而无需线程的上下文切换开销。Greenlet 提供了更细粒度的控制,可以在协程之间显式切换。

SQLAlchemy 中的异步支持

在 SQLAlchemy 1.4 中,引入了对异步操作的支持。这一功能的核心是通过 asynciogreenlet 实现的。asyncio 是 Python 的内置库,用于编写异步代码,而 greenlet 则用于在协程之间同步和异步代码切换。

使用 Greenlet 桥接上下层异步接口

SQLAlchemy 的异步实现很巧妙,它通过 Greenlet 桥接了上层的异步接口和底层的异步驱动接口,使得中间层可以继续使用同步代码执行。
当你执行一个异步数据库操作时,SQLAlchemy会进行以下过程:

  1. SQLAlchemy 会启动一个 Greenlet,将该操作交给 Greenlet 处理。
  2. 在 Greenlet 中,代码以同步方式继续执行,直到需要调用底层异步接口。
  3. 调用底层异步接口时,SQLAlchemy 会返回一个协程对象,此时 Greenlet 会切换出去,并将控制权返回给上层的异步接口。
  4. 上层异步接口接收到返回的协程对象后,使用 await 关键字进入 Python 的异步环境继续执行。当下次需要调用异步接口时,重复上述过程,形成一个闭环。
    这种机制使得 SQLAlchemy 只需要适配少量代码,提供强大的异步数据库操作支持。

官方给出的示意图

在这里插入图片描述

Greenlet 切换到同步的源代码

在这里插入图片描述

结论

我们可以利用这一思想,让同步代码在真正的异步环境中运行。只需正确封装上下层接口,就能在同步代码中享受异步的并发能力。

http://www.lryc.cn/news/420556.html

相关文章:

  • 父类引用指向子类对象
  • 分享一个基于Spring Boot的面向社区的智能化健康管理系统的设计与实现(源码、调试、LW、开题、PPT)
  • 【扒代码】reduction参数是什么
  • Python,Spire.Doc模块,处理word、docx文件,极致丝滑
  • redis的安装与命令
  • 【C++】特殊类设计类型转换
  • 为git 命令行 设置代理环境变量
  • 自定义linux某些常见配置
  • 告别手动操作!KeyMouseGo实现自动化工作流
  • 大型语言模型微调 新进展-4篇 论文
  • 专业课140+杭电杭州电子科技大学843信号与系统考研经验电子信息与通信工程真题,大纲,参考书。
  • php 中 (0 == ‘abc‘) 为真
  • MacOS Anaconda 安装教程及虚拟环境创建
  • Mac快速配置ADB环境变量
  • Kylin的工作原理及使用分享
  • python 使用seleniumwire获取响应数据
  • 用C语言实现双向链表
  • Github 2024-08-10 Rust开源项目日报Top10
  • 深入解析 ESLint 配置:从零到精通
  • BTC连续拉涨,击碎空头幻想
  • 【Spring】Sping笔记01
  • Gridcontrol纵向/横向合并单元格
  • 从周杰伦的《青花瓷》三次更名看方文山的国学情怀与工匠精神
  • HATS:分层图注意力神经网络用于股票预测
  • 【日常记录-MySQL】MySQL设置root用户密码
  • 高级Web安全技术(第二篇)
  • 前端实现文件下载常用几种方式
  • Isaac Lab 安装 (ubuntu22.04环境)
  • todoList清单(HTML+CSS+JavaScript)
  • LVS集群实现四层负载均衡详解(以nat,dr模式为例)