Channels拓展Django,支持WebSocket协议,Channels简介

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/JosephThatwho/article/details/102556664

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基本配置

  1. 安装
pip install -U chnnels
  1. 在Django中注册
INSTALLED_APPS = [
    ...
    'channels',
]
  1. 在根目录或配置路径下创建routing.py文件
from channels.routing import ProtocolTypeRouter

application = ProtocolTypeRouter({
    ...
})
  1. 在settings中添加ASGI_APPLICATION标示刚创建的routing.py为根应用
ASGI_APPLICATION = 'project.routing.application'

猜你喜欢

转载自blog.csdn.net/JosephThatwho/article/details/102556664
今日推荐