Django - Channels (Daphene 的使用小结)

首先推荐阅读下面博文,清晰的讲述了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 &

 

posted @ 2021-04-26 11:02  TonyZhang24  阅读(1653)  评论(0编辑  收藏  举报