firebase - 更改 firebase 数据模型(同时生产多个应用程序版本)

标签 firebase architecture firebase-realtime-database

当您的生产环境中有多个版本的 iOS 应用时,更改 Firebase 数据模型的最佳方法是什么?

由于中间没有“应用程序服务器”层,数据库模型中的任何更改都可能会破坏旧版本的应用程序。

与性能相关的问题示例:

在 1.0 版本中,我天真地将与帖子相关的所有内容都保存在“/posts/”下。现在,在 2.0 版中,我想采纳 Firebase 的建议并添加“/user-post”端点以快速列出给定用户的所有帖子。

使用 iOS 应用程序 1.0 版的用户不会向“/user-posts”写入任何数据,因为该端点以前并不存在。因此,使用 2.0 版本的用户看不到使用旧版本应用程序的用户创建的任何帖子。

理论上,我可以在某处创建一个服务器来监听“/post/”上的更改并将它们添加到“/user-posts”中。不过,如果您的应用程序有很多不同版本,那么随着时间的推移,这似乎很难维护。

问题的新功能示例:

假设在您的移动应用程序 1.0 版本中,您将新博客文章写入“/posts/”。现在,在应用程序的 2.0 版中,您引入了 Teams 功能,并且所有帖子都需要位于“/team/team-id/posts”中。

尚未升级到 2.0 版本的人仍将写入“/posts”。使用 2.0 版本并从“/team/team-id/posts”中阅读的人将看不到这些帖子。

我意识到您可以同时保留两个端点(以及基于团队 ID 的索引/帖子),但随着时间的推移,这似乎很难维护。

传统解决方案:

如果我使用 Django 或 Express 之类的东西,我会进行数据库迁移,然后更新服务器端端点以创建博客文章。

这将从客户端对数据库进行更改。理论上,我可以使用 Firebase 在我的架构中添加应用程序服务器层,但这似乎并不推荐:https://firebase.googleblog.com/2013/03/where-does-firebase-fit-in-your-app.html

最佳答案

我建议您使用 Firebase Remote Config 通过 UIAlertController 或其他屏幕(如果有可用更新)显示警报。您可以强制用户更新到当前版本,以后就不会出现问题,因为无法创建使用旧代码的帖子。

回答您的问题: 我会开发一个不同的应用程序,将其添加到同一个 Firebase 项目中,然后让该应用程序将所有旧数据转换为新数据模型。因此,您可以在发布新版本后执行一次此操作,并将旧用户数据转换为新数据模型,一切顺利。您还可以为每个对象拥有一个类似 databaseVersion 的属性。

为了防止将来出现问题,您可以在 Firebase 实时数据库 中添加一个名为 app-version 的通用属性。在每次发布之前,应用程序都会检查是否有更新的版本。如果没有,用户可以添加帖子,但如果有更新的版本,您可以通过 UIAlertController

显示消息/警报

关于firebase - 更改 firebase 数据模型(同时生产多个应用程序版本),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40349274/

相关文章:

ios - Firebase 数据库突然返回 nil

c# - 适当的大型枚举设计

architecture - 在 Visual Studio 中设置 "enterprise"项目的最佳实践?

android - 我应该将我的 firebase 数据库迁移到 firestore 数据库吗?

java - 构建为发布 APK 后出错,但调试 APK 没有错误 - 错误 : Found two getters or fields with conflicting case sensitivity

java - 将项目依赖库移动到tomcat中的公共(public)文件夹

android - 当字段名称中有空格时 @PropertyName 无法正常工作

firebase - 如何更改 Firebase 实时数据库位置?

firebase - 如何从fire store中获取多行并显示在数据表中--FLUTTER

android - 在请求数据时以及我们没有使用 firebase 身份验证的情况下,如何为 firebase firestore 编写安全规则?