2

我对 greenlets 和 gevent 还是陌生的,但据我了解,greenlets 在显式 yield 语句或阻塞 I/O 操作上屈服于其他 greenlets。但是使用 print 语句写入标准输出会阻塞吗?那么使用 logging 模块写入 stdout、stderr 或本地磁盘或 NFS 上的文件呢?

对打印语句或日志记录方法的调用会导致 greenlet 切换吗?

4

1 回答 1

1

print 语句总是阻塞的,不会切换到其他greenlets。避免在任何 Gevent 服务器代码中打印指令。

较新的 Gevent 版本具有异步文件 I/O gevent.os.tp_read,可与日志记录模块一起使用以实现非阻塞操作。在这种情况下,日志语句将导致 Greenlet 上下文切换。

于 2013-09-30T13:03:32.397 回答