版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
Channels
整合了四个组件:
channels, Django整合层
Daphne, HTTP和Websocket终端服务器
asgiref, ASGI基础库
channels_redis, Redis通信层后台
可以通过channels.http.AsgiHandler包裹Django的视图,也可以让Django视图和Channels的ASGI应用分开运行
Channels和ASGI将连接分为scope和一系列events
scope是一条连接的详细信息的集合,比如web请求的路径,WebSocket的原始IP地址,发起聊天机器人的用户等
consumer可以看作Django的视图,独立的ASGI应用。是Channels的基础单元,他可以消解(cosume) events。当一条请求或套接字进来,Channels根据陆游表找到对应的consumer,并建立其副本。consumer是产期运行的,也可以用来处理HTTP请求。
Channels底层是完全异步的事件循环,他允许定义同步的线程,作相应的阻塞操作,也可以通过async def func():
定义完全异步的consumer
Channels让用户通过熟悉的Django语法拓展Django可以处理的协议
一般情况下,一个套接字或连接由一个服务器进程处理,但复杂的应用架构往往需要进程间通信。这个问题可以通过轮询数据库完成,但Channels提供了通信层(channels layer)的概念用于进程间通信。
Channels基本配置
- 安装
pip install -U chnnels
- 在Django中注册
INSTALLED_APPS = [
...
'channels',
]
- 在根目录或配置路径下创建routing.py文件
from channels.routing import ProtocolTypeRouter
application = ProtocolTypeRouter({
...
})
- 在settings中添加ASGI_APPLICATION标示刚创建的routing.py为根应用
ASGI_APPLICATION = 'project.routing.application'