在云原生APP的开发背景下,需要一套用于信息存储、即时同步、原子修改、离线缓存的数据库中间件,远程修改Serverless数据库,实现脱离服务端接口的目的。 为满足以上需求,而设计实现了Realtime DB这样一个中间件。通常应用在以下场景:
- 即时通信
- 状态同步
- 实时动态
- 团队协作
- 其他
本文介绍的就是Google 的 Realtime DB 数据库 Firebase Realtime Database。数据以 JSON 格式存储并实时同步到每个连接的客户端。当使用 Apple 平台、Android 和 JavaScript SDK 构建跨平台应用时,所有的客户端都共享一个 Realtime Database 实例,并自动接收包含最新数据的更新。
主要功能:
- 实时同步:Firebase Realtime Database 使用的不是常见的 HTTP 请求,而是使用数据同步机制。每当数据发生变化时,任何连接的设备都会以毫秒级的速度收到更新。它可提供协作式与沉浸式体验,而且无需编写网络代码。
- 离线:Firebase 应用即使在离线状态仍会保持响应,因为 Firebase Realtime Database SDK 会将您的数据永久保留在磁盘上。一旦重新建立连接,客户端设备会收到期间错过的任何更新,并与当前服务器状态进行同步。
- 可从客户端设备访问:移动设备或网络浏览器可以直接访问 Firebase Realtime Database,因此不需要应用服务器。安全和数据验证均通过 Firebase Realtime Database 安全规则提供,这些基于表达式的规则会在读取或写入数据时执行。
- 扩容到多个数据库:通过将数据拆分至同一 Firebase 项目中的多个数据库实例,来支持大规模的应用数据需求。在项目中使用 Firebase Authentication 可以简化身份验证,并可跨多个数据库实例验证用户身份。使用针对每个数据库实例的自定义 Firebase Realtime Database 安全规则,您可以控制对各个数据库的数据访问。
工作原理:
Firebase Realtime Database 允许从客户端代码中直接安全地访问数据库,得益于此,能够构建功能丰富的协作式应用。数据会永久性地保留在本地,即使处于离线状态,实时事件仍会继续触发,给最终用户提供良好的即时性体验。当设备重新连接到网络时,Firebase Realtime Database 会将本地数据变化与客户端离线期间发生的远程更新同步,自动合并任何不一致的数据。
Realtime Database 提供灵活的基于表达式的规则语言(称为“Firebase Realtime Database 安全规则”),可以定义您的数据结构以及何时可以读取或写入数据。当与 Firebase Authentication 集成时,开发者可以定义什么人可以访问什么数据以及如何访问数据。
Realtime Database 是一种 NoSQL 数据库,因此具有不同于关系型数据库的优化方向和功能特点。Realtime Database API 的设计只支持可以快速执行的操作。这使您能够构建实时性更强的体验,即使服务数百万的用户,响应速度也丝毫不受影响。
实现路径:
1. 集成 Firebase Realtime Database SDK :通过 Gradle、CocoaPods 或脚本添加方式快速添加客户端。
2. 创建 Realtime Database 引用:引用您的 JSON 数据(如“users/user:1234/phone_number”)来设置数据或订阅数据变化。
3. 设置数据并监听变化:使用这些引用写入数据或订阅变化。
4. 启用离线持久留存:允许将数据写入设备本地磁盘,以便供离线时使用。
5. 保护数据:使用 Firebase Realtime Database 安全规则来保护数据。