首先推荐阅读下面博文,清晰的讲述了channels 的来龙去脉。
https://www.cnblogs.com/skying555/p/5698115.html
总结
1. server & worker
Channels将 Django分成了两部分:接口服务 (Daphne),消息消费者(worker)。所以想要处理HTTP 请求,我们得运行一个worker
python manage.py runworker
(顺便说一句,我们仍然可以通过运行python manage.py runserver命令来做本地测试。当这么做时, Channels只是在同一进程里运行起Daphne和一个worker。)
2. 多实例: 服务和消费者示例
# 多服务 daphne xxx.asgi:channel_layer --port 8000 --bind 0.0.0.0 -v2 & daphne xxx.asgi:channel_layer --port 8002 --bind 0.0.0.0 -v2 & # 多消费者 python manage.py runworker -v2 & python manage.py runworker -v2 & python manage.py runworker -v2 & python manage.py runworker -v2 & python manage.py runworker -v2 & python manage.py runworker -v2 & python manage.py runworker -v2 & python manage.py runworker -v2 &
3. 关于AWSGI - Django, http请求的小结
3.1 使用一个daphene启动Django服务后,当处理一个http 请求时,若只有一个worker在处理(未完成时)会挂起AWSGI server, 导致网站暂时无法访问或延迟访问。
3.2 推荐给一个daphne配置多个worker,配置的方法参考机器CPU-core/processer 数量,以及实际并发的数量。
3.3 解决 Daphne timeout:503: 给daphne添加超时设置(官方说法默认为 60s,实测大概是120s)
daphne xxx.asgi:channel_layer -t 300 --port 8000 --bind 0.0.0.0 -v2 &