我想与您分享过去几周我要解决的架构问题。
我必须设计一个平台,该平台公开一个REST API, 由移动应用和网站使用
到目前为止,一切都很简单。现在来了我还没有整理好的复杂部分。目前,让我们忘记前端,而专注于后端部分,请考虑以下要求:
- 该平台将使用MongoDB (我已经测试了其他NoSQL数据库,但目前这是唯一具有所有功能的数据库 我需要的功能)
- 必须具有超级可扩展性,才能向数千名用户提供服务
- 必须至少通过Facebook和Google允许 oAUTH身份验证
我已经使用各种技术进行了各种测试,但是我还无法确定哪种软件是实现目标的最佳软件堆栈(或云提供商):
首次尝试
最初,我开始探索Firebase(满足第2点和第3点的要求),但有以下限制:
第二次尝试
然后我移到Mongo Stitch,甚至在这里问题也大致相同:可以在本地进行开发,但是(如果我没有误解this doc)进行测试,则必须在上面部署代码云端。如果这是真的,那么这是不可用的方法,因为它会大大减慢开发速度,并且不允许团队合作。此外,MongoDB Cloud平台不提供静态资源托管。这不是一个严重的问题,但是如果有,那就更好了
第三次尝试
我正在尝试使用NodeJS(与Express和Mongoose一起)来建立一个环境,使您可以快速开发和本地测试。但是现在我必须了解如何将其带到云上。我想尝试一种混合方法,该方法可以将开发速度与云系统的功能和功能结合在一起(可能是Firebase,因为最终它是最复杂的平台):我想尝试开发所有东西在本地,将业务和数据访问组件隔离在单独的js库中。然后,当我在本地工作时,我会将一条快速路线映射到业务功能;相同的业务功能将映射到相关的Firebase功能上。
有人尝试过这种工作方式吗?
我正在考虑的另一件事是将运行时分别部署在两个不同的云中。会有性能问题吗?或这些云服务的性能如此之差以至于可以忽略不计。考虑到这一点,将有两个远程处理级别:
AppMobile ===> REST服务器(Firebase)===> MongoDb(Mongo Atlas)
您如何看待?任何意见或经验将不胜感激。 如果您需要澄清,请告诉我 预先感谢
答案 0 :(得分:0)
对于可伸缩性,MongoDB依赖关系和OAuth的要求,最好的堆栈之一是使用Node.js和MongoDB。 Node.js具有超强的可扩展性,并具有与MongoDB进行通信的库。您可以在本地进行开发并将其推送到云中。另一种选择是使用Node.js(用于前端和OAuth),并使用中间层Java应用程序(例如Spring Boot)与MongoDB(作为数据库)一起为ReSTful调用提供服务。