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 &
补充Daphne 常用配置及参数
--port: 指定 Daphne 监听的端口,默认为8000。
--bind: 指定 Daphne 监听的 IP 地址和端口,格式为ip:port。
--unix-socket: 指定 Daphne 监听的 Unix 域套接字路径。
--verbosity: 指定日志详细程度,可选的值有 0(只输出错误信息)、1(输出错误信息和警告信息)、2(输出错误信息、警告信息和一般信息)。
--access-log: 指定访问日志文件路径,如果不指定,则不会记录访问日志。
--root-path: 指定静态文件根目录,用于提供静态文件服务。
--ping-interval: 指定 Websocket ping 的间隔时间,单位为秒,默认为20秒。
--ping-timeout: 指定 Websocket ping 超时时间,单位为秒,默认为30秒。
--http-timeout: 指定 HTTP 请求超时时间,单位为秒,默认为120秒。
--websocket-timeout: 指定 Websocket 连接超时时间,单位为秒,默认为120秒。