今年疫情的突袭,改变了不少人以往在生活和工做中的方式,视频会议、协同编辑、在线直播 / 教育等业务场景凸显重要性。人们经过线上方式,实时的获取信息、同步信息,以快捷且不受空间限制的形式完成沟通、学习、工做等需求。html
本文将以微信小程序实时弹幕功能为例,向你们介绍高实时业务场景的功能技术实现过程。前端
短轮询web
短轮询是客户端每隔一段时间向服务器发出请求,服务器端在收到请求后,不管是否有数据更新,都直接进行响应。数据库
长轮询npm
当服务器收到客户端发来的请求后,服务器端不会直接进行响应,而是先将这个请求挂起,而后判断服务器端数据是否有更新。若是有更新,则进行响应,若是一直没有数据,则到达必定的时间限制才返回。小程序
Server-sent Events(SSE)segmentfault
SSE 容许服务器推送数据到客户端,不须要创建或保持大量的客户端发往服务器端的请求,能够实现只要服务器端数据有更新,就立刻发送到客户端。后端
WebSocket微信小程序
WebSocket 是一种网络传输协议,支持双向可靠的通讯。首先须要在客户端和服务器端创建起一个链接,这部分须要 http。链接一旦创建,客户端和服务器端就能够相互发送数据,不存在请求和响应的区别。服务器
实时数据库是知晓云近期推出的重磅基础能力,基于 WebSocket 实现客户端和服务端的实时双向通讯,在云端数据发生变化时立刻通知全部客户端来同步数据,从而改变了以往只能由客户端按需向云端请求或经过定时轮询来刷新数据的单向模式。
实时数据库可让开发者无需投入额外的开发资源,即可轻松、快速的搞定实时性高的业务场景。对于社交聊天、弹幕、多玩家游戏、协同编辑、股票基金实时报价、体育实况更新、视频会议 / 聊天、基于位置的应用、在线教育、智能家居等场景都颇有帮助。
准备
注册一个微信小程序
注册一个知晓云帐号,并创一个知晓云应用
ps:在左侧栏找到「设置」,选项「应用」能够找到开发者 ID,用于知晓云 SDK 初始化。
安装
目前支持的版本 3.14.0-beta.2 及以上。
分析
知晓云 实时数据库有一个限制就是必须先登陆,因此咱们在实现视频弹幕的时候,须要先实现登入登出。
有两个界面状态:
这样子就是一个相对完备的应用了。
首先是订阅一个表的事件 :
const Danmu = new BaaS.TableObject('danmu')const subscription = MyTable.subscribe('create', { oninit: () => { console.log('订阅成功') }, onerror: error => { console.log('订阅失败', error) }, onevent: ({after}) => { console.log('接收到知晓云推送过来的消息', after) // 这个时候就能够调用小程序视频组件的 API 产生弹幕效果 }, })
每次订阅都会返回一个订阅关系对象 subscription,使用者能够在特定时机调用 subscription.unsubscribe() 取消订阅。好比说小程序页面加载的时候发起订阅,页面销毁的时候取消订阅(网页端,刷新的时候不须要主动调用取消订阅也会取消订阅)。
而后,能够向这个表写入一 条 数据:数据将写到知晓云,知晓云再 将 数据的变化推送到全部跟这张表创建了 create 订阅关系的客户端。
咱们能够在微信开发者工具看到小程序界面,输入弹幕内容,点击发送弹幕为数据表新增一条弹幕数据,小程序端便可收到新增的数据行,并进行弹幕显示。
弹幕小程序界面
以上是实时弹幕功能的技术实现过程,如需观看视频教学,请访问:
https://www.bilibili.com/video/BV1hz4y1Q7cC/
参考材料
知晓云 API
初始化
获取当前用户
登入
登出
新增数据记录
实时数据库(WebSocket)
微信小程序 API
知晓云成立于 2017 年 8 月 8 日,是国内首家专一于小程序开发的后端云服务,为以小程序为表明的大前端开发者提供最低门槛的 Serverless 无服务架构接入体验。
它免去了小程序等大前端开发中服务器搭建、域名备案、数据接口实现等繁琐流程。让开发者专一于业务逻辑的实现,使用知晓云开发小程序、app、网站,门槛更低,效率更高。