Websocket
即时通讯
1.需求
即时通讯工具一定要保障的是即时性
基于现在的通讯协议HTTP
要如何保障即时性呢?
2.短连接型
基于HTTP
短连接如何保障数据的即时性
HTTP
的特性就是无状态的短连接,即一次请求一次响应断开连接失忆,这样服务端就无法主动的去寻找客户端给客户端主动推送消息
1.轮询
即:客户端不断向服务器发起请求索取消息
优点:基本保障消息即时性
缺点:大量的请求导致客户端和服务端的压力倍增
2.长轮询
即:客户端向服务器发起请求,在HTTP
最大超时时间内不断开请求获取消息,超时后重新发起请求
优点:基本保障消息即时性
缺点:长期占用客户端独立线程,长期占用服务端独立线程,服务器压力倍增
3.长连接型
基于socket
长连接,由于长连接是双向且有状态的保持连接,所以服务端可以有效的主动的向客户端推送数据
1.socketio
长连接协议
优点:消息即时,兼容性强
缺点:接入复杂度高,为保障兼容性冗余依赖过多较重
2.websocket
长连接协议
优点:消息即时,轻量级,灵活适应多场景,机制更加成熟
缺点:相比socket
兼容性较差
总体来说,Socketio
紧紧只是为了解决通讯而存在的,而Websocket
是为了解决更多更复杂的场景通讯而存在的
这里推荐Websocket
的原因是因为,我们的Django
框架甚至是Flask
框架,都有成熟的第三方库
而且Tornado
框架集成Websocket
4.Django
实现Websocket
使用Django
来实现Websocket
服务的方法很多在这里我们推荐技术最新的Channels
库来实现
4.1.安装DjangoChannels
Channels
安装如果你是Windows
操作系统的话,那么必要条件就是Python3.7
pip install channels
4.2.配置DjangoChannels
1.创建项目ChannelsReady
django-admin startprobject ChannelsReady
2.在项目的settings.py
同级目录中,新建文件routing.py
# routing.py
from channels.routing import ProtocolTypeRouter
application = ProtocolTypeRouter({
# 暂时为空
})
3.在项目配置文件settings.py
中写入
INSTALLED_APPS = [
'channels'
]
ASGI_APPLICATION = "ChannelsReady.routing.application"
4.3.启动带有Channels
提供的ASGI
的Django
项目
You have 17 unapplied migration(s). Your project may not work properly until you apply the migrations for app(s): admin, auth, contenttypes, sessions.
Run 'python manage.py migrate' to apply them.
February 01, 2020 - 17:27:13
Django version 3.0.2, using settings 'ChannelsReady.settings'
Starting ASGI/Channels version 2.4.0 development server at http://0.0.0.0:8000/
Quit the server with CTRL-BREAK.
很明显可以看到ASGI/Channels
,这样就算启动完成了
4.4.创建Websocket
服务
1.创建一个新的应用chats
python manage.py startapp chats
2.在settings.py
中注册chats
INSTALLED_APPS = [