我正在尝试使用 Django 和 Waitress 构建一个 python 网络服务器,但我想知道 Waitress 如何处理并发请求,以及何时可能发生阻塞。
虽然Waitress 文档提到可以使用多个工作线程,但它并没有提供很多关于它们如何实现以及 python GIL 如何影响它们的信息(强调我自己的):
当通道确定客户端至少发送了一个完整的有效 HTTP 请求时,它会使用“线程调度程序”调度一个“任务”。线程调度程序维护一个固定的工作线程池,可用于执行客户端工作(默认情况下,4 个线程)。如果在调度任务时工作线程可用,则工作线程运行该任务。该任务可以访问通道,并且可以写回通道的输出缓冲区。当所有工作线程都在使用时,计划任务将在队列中等待工作线程可用。
Stackoverflow 上似乎也没有太多信息。从问题“Gunicorn 的 gthread 异步工作者是否类似于 Waitress?” :
Waitress 有一个主异步线程来缓冲请求,并在请求 I/O 完成时将每个请求排入其同步工作线程之一。
这些陈述没有解决 GIL(至少从我的理解来看),如果有人能详细说明工作线程如何为 Waitress 工作,那就太好了。谢谢!