Greenlet是Python轻量级协程模块,提供比线程更高效的协作式并发,需手动切换执行流,常用于gevent等异步框架底层,适合高并发I/O场景但不支持多核并行。
Greenlet 是 Python 中一个轻量级的协程(微线程)实现模块,属于 Stackless Python 的衍生技术,由第三方库提供(通常通过 greenlet 包安装)。它允许你在单个线程内手动控制多个执行流之间的切换,每个 greenlet 拥有自己的栈空间,可以独立保存局部变量和调用栈。
Greenlet 的基本特点
Greenlet 提供了一种比线程更轻量的并发方式:
-
轻量高
效:创建和切换开销远小于操作系统线程。 - 协作式调度:不自动抢占,需要显式调用 switch() 方法进行上下文切换。
- 共享主线程:所有 greenlet 运行在同一个 OS 线程中,不能利用多核并行,但避免了锁竞争的复杂性。
- 手动控制流程:你可以精确控制哪个 greenlet 在何时运行。
如何使用 Greenlet
安装 greenlet 模块:
pip install greenlet一个简单的例子:
from greenlet import greenletdef task1(): print("进入任务1") gr2.switch() # 切换到任务2 print("回到任务1")
def task2(): print("进入任务2") gr1.switch() # 切换回任务1
gr1 = greenlet(task1) gr2 = greenlet(task2)
gr1.switch() # 启动任务1
输出结果为:
进入任务1进入任务2
回到任务1
Greenlet 和 Gevent 的关系
Greenlet 本身只是一个底层的协程机制,没有内置 I/O 多路复用或异步网络支持。但在实际开发中,它常被用作更高层框架的基础,比如 Gevent。Gevent 就是基于 greenlet + libev 或 libuv 实现的高性能并发库,通过 monkey patch 让标准库的阻塞操作变成异步非阻塞,从而实现真正的高并发网络应用。
适用场景与注意事项
Greenlet 适合用于需要大量并发 I/O 操作的场景,如爬虫、Web 服务器、长连接服务等。
- 不要在 CPU 密集型任务中使用,因为它无法并行利用多核。
- 必须小心管理切换逻辑,避免死锁或无限嵌套。
- 异常传播需特别处理,不同 greenlet 之间异常不会自动传递。
基本上就这些。greenlet 是理解 Python 协程底层原理的重要一环,虽然现在很多人直接使用 asyncio 或 gevent,但了解 greenlet 能帮助你更深入掌握异步编程的本质。

效:创建和切换开销远小于操作系统线程。






