Django和Channels以及ASGI线程问题

3

我使用Django和Channels(在ASGI模式下)时遇到了问题。

当我设置Django Channels并使用ASGI模式时,我的应用程序为每个HTTP请求和从通道发送的每条消息创建一个新线程。

例如,假设我的应用程序是一个简单的回声聊天服务器。当我运行服务器并请求连接到套接字作为客户端时,线程数增加,当我再次向套接字发送消息时,线程数也会因每条消息而增加。

您知道原因吗?我该如何修复或限制它?

1个回答

4

对于同步请求,Channels使用线程池。如果在事件循环中运行HTTP请求,则每个数据库查询和缓存命中都会锁定事件循环。

如果您没有设置环境变量ASGI_THREADS,它将使用 concurrent.futures.ThreadPool 设置的默认值,默认值是CPU核心数乘以5,我认为这太高了。请将ASGI_THREADS设置为较低的数字,并使用多个Daphne进程。通过使用较少的线程和多个进程,您可以避免Python全局解释器锁定引起的某些减速问题。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接