写点什么

如何使用云开发数据库构建更生动的小程序?

2020 年 7 月 13 日

如何使用云开发数据库构建更生动的小程序?

长连接服务被广泛应用在消息提醒、即时通讯、推送、直播弹幕、游戏等场景。本篇文章将介绍云开发数据库的长连接服务 - 实时数据推送,使用它来构建更生动的小程序。


什么是实时数据推送?


通过云开发数据库的实时数据推送能力,小程序端可实时监听数据库变更,即它支持根据开发者给定的查询语句进行监听,每当查询语句的结果发生变化时,小程序端就会收到包含更新内容的推送,并对实时数据变化做出响应。


具体示例如下图:客户端 1 修改数据且符合监听条件,当数据库收到变更时,会将客户端 1 的变更内容推送到其它客户端。



提供哪些能力来帮助开发者构建小程序


自建长连接服务,需要设计繁杂的系统架构,并且有大量的开发工作,使得开发成本较高。当长连接服务开发完成投入使用后,将不可避免的会带来额外的维护工作。对于基础设施、服务安全等维护也需要耗费大量的时间成本和人力成本。此时,开发者可以进行小程序的实际开发工作。接入微信鉴权体系来获取用户登录态、使用微信开放接口等,基于长连接服务来实现具体的业务逻辑。


使用实时数据推送有如下优势:


  1. 零开发


使用实时数据推送无需通过编写服务端代码来自建完整服务,降低了开发成本和开发者的使用门槛,可以将精力聚焦在核心业务的设计与开发上。


  1. 免鉴权


使用实时数据推送无需接入微信鉴权体系,天然集成了原生微信能力,与微信的登录无缝整合,开箱即用,免鉴权获取微信用户信息、使用微信开放接口。减少了开发者对鉴权功能的开发和维护工作。


  1. 零维护


使用实时数据推送无需维护基础设施、安全管理等问题,降低维护成本。


整体架构


大家都听过网上段子说哪有什么岁月静好,只是有人替你负重前行。我们刚才了解了实时数据推送的零开发、零维护、免鉴权等天然优势,那么这些能力岁月静好的背后是谁替它们负重前行呢?让我们来揭开实时数据推送技术架构的神秘面纱。



请求从小程序到接入层经过的是 WebSocket 协议,再到安全校验层进行权限验证。安全校验提供简单的 ACL 标记,也支持高级的数据库安全规则语法实现精细化访问权限控制,可以根据业务实际情况进行选择。对于路由层以及监听推送层,将从可用性、可靠性和性能方面来进行介绍。


可用性


对于服务首当其冲是可用性。首先是异常节点自动剔除来确保在部分节点出现问题时,服务正常可用。实时数据推送路由层通过 Tars 的熔断和自动剔除机制来屏蔽掉异常节点。监听推送层使用 ETCD 实时心跳检测,2 秒上报心跳、6 秒检测到异常,立即执行相关处理逻辑来实现异常节点自动剔除。其次通过一致性哈希方案提升性能、保证可用性。每次长轮询请求都有 QueryID,请求从路由层到监听推送层的对应关系由一致性哈希生成算法,使得监听推送层负载均衡。最后还有相同条件对应相同的 QueryID 来提高性能。


可靠性


从小程序到实时数据推送服务是长轮询且无状态,为业务可靠提供保驾护航。事件自增 ID 可以保证收到推送事件是有序的。此外,对事件进行了本地和 Redis 的两级缓存来确保数据安全。支持客户端掉线 3 分钟,事件不丢失,断线重连后仍能正常按序收到事件。


高性能


实时数据推送服务的性能方面,我们做了一些优化工作:


  1. 使用树的数据结构来保存watch条件作为索引,对监听条件匹配索引算法进行优化。

  2. 对于变更事件的匹配,采用多协程并发流水线:匹配事件、推送事件、缓存事件。

  3. 当短时间内有多条符合监听条件的事件产生时,多个事件将会在合并后再推送到客户端。减少了多次推送事件的请求网络耗时,性能提升明显。


简单易用的 API


实时数据推送提供了便捷的 API 供使用。开发者可根据实际场景,按指定集合、查询条件、排序方式、限制返回数量等来实现业务逻辑。更详细的说明可参考微信开放文档 - 云开发实时数据推送。



丰富的应用场景


实时数据推送可以应用到许多实际业务场景中,如即时通信、状态同步以及团队协作等方面。无论是小程序或小游戏都可以使用云数据库的实时数据推送来实现相关场景的实际业务功能。


  1. 即时通信

  2. a. 小程序:直播聊天室、弹幕等

  3. b. 小游戏:区服聊天、房间聊天、私信功能、动态消息等


成语偷菜小游戏就是一个经典的即时通信客户案例,它利用实时数据推送实现了偷菜的动态消息提醒。



下图是在线聊天室 Demo 演示,可在微信开发者工具中开通云开发体验。



  1. 状态同步

  2. a. 小程序:聊天提示状态好友正在输入、好友1V1问答PK等

  3. b. 小游戏:五子棋等


微信读书每日一答小程序的问答 PK 环节也使用到了实时数据推送,在对答游戏中即时同步双方答题的倒计时、分数、结果等状态。



下图是使用实时数据推送实现的五子棋小游戏,推送服务主要用于同步黑白两手棋子的状态。



  1. 团队协作

  2. a. 在线共享文档

  3. b. 项目管理协作


结语


以上是给大家分享的内容,希望能帮助到各位开发者们更好地应用实时数据推送,为小程序锦上添花。最后,欢迎关注云开发公众号,不定时推送最新功能以及云开发实战高质量技术文章。


2020 年 7 月 13 日 10:191009

评论 1 条评论

发布
用户头像
类似rethinkdb的做法?
2020 年 07 月 13 日 11:32
回复
没有更多了
发现更多内容

SQL数据库:CASE表达式

大规模数据处理学习者

CASE表达式

报告显示国际区块链监管呈三大趋势

CECBC区块链专委会

区块链 货币 监管

限流10万QPS、跨域、过滤器、令牌桶算法-网关Gateway内容都在这儿

周老师

Java 微服务 算法 并发 QPS

有点意思的gif动图生成平台开发实战(二)

徐小夕

Java Vue 前端 GIF React

花四个月和阿里面试官“大战”7回合,成功将其“斩于马下”!复盘面试题及答案!

Java架构追梦

Java 阿里巴巴 面试题 面试经历 java架构

覆盖全网的阿里微服务架构有多牛:K8S+实战+笔记+项目教程

马士兵老师

Java 程序员 微服务 Spring Cloud 阿里云 K8S

程序员求助:腾讯面试题,64匹马8个跑道,多少轮选出最快的四匹

Java架构师迁哥

Vokenization:一种比GPT-3更有常识的视觉语言模型

脑极体

代码写的烂才是原罪?字节三面+微信四面+PayPal四面,大厂面经分享

Crud的程序员

架构 面试 数据 字节

读完某C++神作,我只记住了100句话

MySQL从删库到跑路

c++

企业工作流设计原则及注意事项

力软.net/java开发平台

工作流

干货!直观地解释和可视化每个复杂的DataFrame操作

计算机与AI

Python pandas 数据处理

数字货币助力支付体系高效运行

CECBC区块链专委会

金融

adb的常用操作命令

Yolanda_trying

《精通lambda表达式:Java多核编程》.pdf

田维常

Lambda

架构师第一期作业(第 9 周)

Cheer

作业

程序员如何判断跳槽岗位是否有坑!

Java架构师迁哥

云算力挖矿模式系统开发,云算力平台搭建

13530558032

牛批!2w字的Java集合框架面试题精华集(2020最新版),赶紧收藏。

Java架构之路

Java 程序员 架构 面试 编程语言

「Spring Boot 2.4 新特性」一键构建Docker镜像

AI乔治

Java Docker 架构

“3+3”看华为云FusionInsight如何引领“数据新基建”持续发展

华为云开发者社区

数据库 新基建 华为云

揭秘双11:前端技术体系

阿里云情报局

前端 前端进阶

程序员双十一剁手指南

数据君

腾讯云 程序员

这套JVM核心知识你要全都会,月薪还不过18K可以直接跳槽了

小Q

Java 学习 架构 面试 JVM

那个小白还没搞懂内存溢出,只能用案例说给他听了

田维常

内存溢出

即将写入MySQL源码的官方bug解决之路

数据君

MySQL

超越竞争文化:致善式创新能否打造手机产业的“海法城”

脑极体

Alibaba首发的《Java技术成长笔记》,渴望提升自己的程序员的必备宝典!

Java架构之路

Java 程序员 架构 面试 编程语言

不要拿区块链做挡箭牌

CECBC区块链专委会

区块链

两句话给面试官讲清楚IOC

执墨

spring ioc 依赖倒置原则 springioc 控制反转

断供,危机or契机?开源商业化or社区化?后疫情下的开源路这样走 | 大咖对话

易观大数据

如何使用云开发数据库构建更生动的小程序?-InfoQ