发布网友 发布时间:2024-10-03 06:38
共1个回答
热心网友 时间:2024-11-20 08:01
导读:本篇文章首席CTO笔记来给大家介绍有关django怎么主动推送的相关内容,希望对大家有所帮助,一起来看看吧。
djangowebsocket做个比喻,如果说A是服务端,B是客户端,现在要在A家里吃火锅,虽然A说你人来就行,但是B心想总得带点东西过去,于是去了市场.
先到了蔬菜店,B想买点菠菜,但又怕A家里已经有了,于是给A打电话
B:"我带点菠菜过去吧?"
A:"好"
然后挂断.过一会儿到了水产区
B:"我带点虾过去吧?"
A:"不用"
...如此反复多了之后A突然发现自己确实少准备了一些东西,于是A给主动给B打了电话
A:"我忘准备蘸料了,你买点,然后先别挂掉"
...
A:"再买瓶酒"
...
这就是websocket了
django当让也提供对websocket的支持,虽然这似乎不是他更擅长的东西.我们可以通过channels实现websocket连接
诸如上述例子的场景都是合适的场景
举例来说的话比如聊天室,每个人发送的消息都要实时显示在别人的屏幕上.
比如说数据监控,波动状态也要实时的呈现在屏幕上,而不是依赖于使用者自己刷新.
需要安装channels,asgi_redis,asgiref,channels_redis.后三个未必都需要装,记不太清了,总之安装过程都在channels的使用文档上.
INSTALL_APPS中需要加上"channels",需要注意的是因为这是一个list,是有先后顺序的,最好把它加在第一个.
这里我们的channel通过redis实现,要在settings.py中配置
这里还有点小坑,官方文档里的hosts不是这种格式,是"uri"这种模式,但是如果你在设置redis密码时机智的设置了特殊符号('#$%'这种),你就会发现redis的uri直接就用不了了,期间尝试各种方法,转义什么的也试了都不行,然后去github上开了个issue,结果作者说我们是通过aioredis连接的,你去找他们的文档吧....
然后就找到了这种方式.
常规的WSGI不支持websocket,所以还需要配置ASGI
ASGI_APPLICATION='project.routing.application'
同wsgi的配置一样,这是指向project文件夹下routing.py文件的application
这里建议大家跟这官方教程的Tutorial走一遍.有个比较悲剧的地方就是网上可以搜到许多channels使用指南,大多都是搭个简易聊天室什么的,然而你用起来可能发现存在各种报错,因为channels升了2.0之后更改了一些方法,而那些教程里基本全都是1.x的版本.
简单说下,首先startapp叫chat,假如这里我们没有进行前后端分离,里面有templates,两个html:index和room分别对应首页和某一个聊天室
新建consumers.py来写websocket方法
如上,connect和disconnect含义分别如函数名.因为是聊天室,所以同一个聊天室内的人应该消息共享,用room_group_name来区分所在的频道.
receive和chat_message是对消息的处理.当一个用户发送消息时,前端把消息通过websocket发送过来,receive收到消息提取关键内容,通过chat_message发送给组内的所有连接.这时保持连接的所有组内人员都会收到这条消息推送,前端收到推送再显示在屏幕上.
定义websocket的地址
类似于django的url(consumers.py就类似于views.py),同级新建routing.py
统一用ws/来区分websocket的连接
剩下常规的页面配置和django一样
views.py:
urls.py:
注意:如果网站是http,连接使用ws,如果是https要修改成wss
剩下的自己找资料吧,笔者对前端了解的不多
本地的话runserver就好了,但是在线上还是得更改启动方式应对高并发.
传统的uwsgi不支持websocket.
gunicorn好像可以同时支持websocket,但是性能不太ok
这里我们用daphne
这里需要额外开个服务,专门负责处理websocket.
ingress中要配置路由跳转
django实现实时消息推送有什么好的方案django实现实时消息推送,数据库数据一有变化就实时反应在页面上用作系统实时监控。在一个HTTP访问周期里,如果要执行一个长时间任务,为了避免浏览器等待,后台必须使用异步动作。
与此同时也要满足实时需求,用户提交了任务后可以随时去访问任务详情页面,在这里用户能够实时地看到任务的执行进度。针对异步任务处理,使用了Celery把任务放到后台执行。
Celery是一个基于python开发的分布式异步消息任务队列,通过它可以轻松的实现任务的异步处理,关于它的使用方法《网易乐得RDS设计》也有提到。Celery在处理一个任务的时候,会把这个任务的进度记录在数据库中。
消息推送直接找专业的平台,例如极光。深圳市和讯华谷信息技术有限公司(极光AuroraMobile,纳斯达克股票代码:JG)成立于2011年,是中国领先的开发者服务提供商,专注于为开发者提供稳定高效的消息推送、一键认证以及流量变现等服务,助力开发者的运营、增长与变现。
后端如何接受传感器大数据(bigdata),指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。大数据的5V特点(IBM提出):Volume(大量)、Velocity(高速)、Variety(多样)、Value(低价值密度)、Veracity(真实性),平台有hadoop
我正在开发一个实时网络应用程序,它将显示从浏览器中的传感器收集的数据.但似乎有两种方法可以做到这一点.在前端我使用Angular4.在后端我使用django.
第一种方法是使用Django创建套接字客户端并直接连接到传感器dadacollector(这是一个raspberrypi).在树莓派上有一个套接字服务器在它上面听.一旦django连接到raspberrypi,raspberrypi就会将数据推送到套接字.然后django可以使用websocket(通过djangoChannels)将数据推送到前端角4.
第二种方法是运行一个独立的python套接字客户端脚本,连接到raspberrypi套接字服务器并将数据保存到数据库中.后端django将每秒查询数据库并获取最新数据.然后使用websocket以与第一种方式相同的方式将数据推送到前端角4.
结语:以上就是首席CTO笔记为大家整理的关于django怎么主动推送的全部内容了,感谢您花时间阅读本站内容,希望对您有所帮助,更多关于django怎么主动推送的相关内容别忘了在本站进行查找喔。