当您的生产环境中有多个版本的 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/