写点什么

App 后端服务,你是选择 AWS 还是 Firebase?

  • 2020-03-02
  • 本文字数:2408 字

    阅读完需:约 8 分钟

App后端服务,你是选择AWS还是Firebase?


我开发原生 Android 应用程序有很长一段时间,最近开始用Flutter开发移动应用程序,并同时使用Firebase和 AWS 作为后端服务。但最近,我不得不为一个移动应用程序找到一个解决方案,这花费我很多时间来选择合适的后端服务。


那 App 的后端服务,你是选择 AWS 还是 Firebase。当然,并不是说AWS就比 Firebase 好,或 Firebase 比 AWS 好。正确的问题应该是:哪种解决方案最适合我的需求?


在此,我分享自己的观点和理解,或许能帮你选择正确服务。


1.服务共同点

核心功能有:


  • 身份验证

  • 推送通知

  • 存储

  • 托管

  • 分析


这些功能,它们都有。因此,你可以用这些平台轻松部署无服务器解决方案。

2.怎样整合后端与应用程序?

集成这些服务最普遍的方法是使用它们的 SDK,但是这符合你的需求吗?

Firebase

Firebase 为 Android、iOS 和 Web 提供 SDK,因此,作为前端开发人员,你可以轻松构建数据驱动的应用程序,而不必受制于后端技能。


Firebase 还有一个 REST API,你能用它构建自己的自定义 API(根据需求)。

AWS

AWS 为移动开发提供一种非常好的解决方案AppSync,你可以把它集成到你的 Android、iOS 和 React Native 中。


AWS AppSync 还未提供对 Flutter 的官方支持,不过,你可以看下这里


如果你想使用 Flutter 开发前端,就必须创建自己的 API。

建议

  • 考虑解决方案的复杂性和业务需求,并考虑可伸缩性,决定是否要创建 API。

  • 如果你希望拥有一个 API,那么就用不到 SDK 了。另外,对于较大的项目,拥有一个 API 更有意义。

  • 如果你的解决方案很简单,并且不想在 API 上投资,那么选择提供 SDK 的服务/前端框架,以便能直接将后端集成到你的前端。

3.双方的各自优势

Firebase 和 AWS 各有优势,哪个更适合你。

AWS

1. 设置不同环境


在 AWS 中,用于开发、测试和生产的不同环境更加“优雅”。


当然,你也能在 Firebase 中这样做,但必须建立不同项目,而这需要更多时间。


2. 持续部署


如果你用过 Netlify 之类的服务,那么 AWS 为持续部署提供另一种优雅的解决方案。同样,你也可以使用谷歌云来实现 CD,但它需要更多配置。


3.GraphQL


面向移动应用程序的 AWS Amplify SDK 与GraphQLApollo紧密集成。


4. 选择数据库


在后端用哪种类型的数据库,完全由你控制,而 Firebase 只提供 NoSQL 数据库。


5. 单包解决方案


AWS 提供应用程序可能需要的所有服务。因此,AWS 是一个云解决方案,你可以完全依赖它来满足所有需求。


如果整个后端都在一个地方,这会更容易理解和维护。

Firebase

1. 专用数据库


Firebase 提供两种专用数据库服务:Cloud Firestore 和 Realtime Database。这两个数据库都是 NoSQL 数据库,因此,你在部署数据驱动的应用程序时不必太操心数据库设置和查询编写。


只要你的需求和要求比较简单,并且知道它未来不会变得更复杂,那么你就可以使用 NoSQL 数据库。


2. 可调用的函数


得益于 Firebase 云函数,你可以创建云函数并通过 URL 设置触发器,以便将侦听器写入数据库。


这些函数类似于 AWS Lambda,但是从应用程序触发一个 Lambda 需要你设置一个 API 网关并添加授权逻辑,这使得实现起来有些困难。


3.质量控制服务


Firebase 提供很多服务来监控和保证应用程序的质量。这些服务包括:


  • 动态链接:将用户导航到你应用程序的正确位置,无论它是否已经安装。

  • 远程配置:使用服务器端配置自定义并试验应用程序行为。

  • 测试实验室:跨设备测试 App。

  • 应用内消息传递:发送用户参与活动。

  • 分析:帮你规划未来的发布和用户参与策略。

  • ML Kit:在应用程序的前端或后端为你的解决方案添加机器学习功能。


4.平台定价(AWS vs Firebase)

这两个平台的价格都很有吸引力,甚至还有一个免费档,所以你无需为任何东西付费,除非你有相当数量的活跃用户。

AWS

AWS 掌握其服务的定价,他们以便宜得多的价格提供许多很棒的服务。随着时间推移,他们实际上能将服务价格降低 80%以上。


这就是为什么,你会发现 AWS 比 GCP 更便宜。对于构建实时应用程序,AWS 提供了相对昂贵的DynamoDB


对于云函数,AWS 提供的服务价格是 Firebase 的一半。

Firebase

虽然 AWS 的某些服务更便宜,但 Firebase 提供一些完全免费的服务,比如:


  • 用户认证——通过FirebaseAuth,等同于AWS Cognito

  • 推送通知——使用 Firebase 云消息传递,相当于 AWS 中的简单通知服务。


对于构建实时应用程序,与 AWS 相比,Firebase 的设置成本似乎要低得多,也更容易。Firebase 负责数据的实时同步,你无需过多操心。


随着用户数量的增加,Firebase 显然是构建实时应用程序的更好选择。但是如果不小心优化你的查询,Firebase会给你寄来一张3万美元的账单


顺便说一句,谷歌在了解发生的事情后,已经放弃一些应用场景。有些东西比平台定价更贵……

5.时间和人力

这是一个需要考虑的重要因素,因为你将需要这些资源来设置、构建和维护应用程序架构。

Firebase

Firebase 非常简单,容易上手。实际上,前端开发人员可以创建和维护整个后端,只需要一点设置方面的知识。


对于创建实时应用程序,Firebase 处理了大量的复杂性,并为你提供一个非常强大且易于使用的 SDK,帮你节省大量时间,而时间就是金钱。

AWS

因为 AWS 提供的服务是 Firebase 的十倍,所以它的使用和维护也要复杂十倍。我想说的是,与 Firebase 相比,AWS 有一点学习曲线。


对于创建实时应用程序,你需要搭配使用 GraphQL API 和 DynamoDB 实例(同样是一个 NoSQL 数据库),并且你还必须设置 API 和数据库,对于一个简单的实时应用程序来说,这似乎显得有些多余。

最后的思考

Firebase

  • 易于设置、使用和维护。

  • 需要你做的决定更少,非常适合简单的应用程序。

AWS

  • 提供更大的灵活性,这对构建大型、复杂的应用程序有很大帮助,但对简单的应用程序来说可能有些多余。

  • 一个潜在的解决方案可以满足你所有的应用程序需求。你可以构建一个整洁打包的解决方案,但是其可能成本更高。


我希望这能帮你做出正确决定,并在尝试构建应用程序时提出更好的问题。


英文原文:


Should You Use AWS or Firebase For the Back end of Your Mobile App?


2020-03-02 07:007436
用户头像

发布了 849 篇内容, 共 591.8 次阅读, 收获喜欢 1605 次。

关注

评论 4 条评论

发布
用户头像
和Firebase与AWS提供的服务比,首选Azure PaaS (1天从小白到大师的学习路线)。进阶后再选Kubernetes (我选择Azure Kubernetes Service)。

Firebase不一定比aws好,反之亦然。但Azure PaaS确实绝对性的比这两个好(不过只限定在.net core和node.js)。关于数据库,网络安全,存储服务,数据处理,分布式管理,数据分析等等等等基本用的到的所有功能,Azure PaaS的学习成本是1天学会所有需要的技术。
2020-03-02 12:12
回复
选择Kubernetes只针对APP的运行~ 其他的PaaS服务不建议用Kubernetes。前列建议使用Azure DevOps做DevOps工作。简直是神器~~ 超级神器~~ 任何手机应用部署+绝大多数主流后端服务,都可以毫无缝隙的快速集成
2020-03-02 12:14
回复
用户头像
都挺好,都用不了 :)
2020-03-02 10:08
回复
哈哈哈
2020-03-02 11:56
回复
没有更多了
发现更多内容

ReactNative进阶(二十八):ES6 Symbol 用法

No Silver Bullet

React Native symbol 1月月更

🏆【Alibaba中间件技术系列】「RocketMQ技术专题」系统服务底层原理以及高性能存储设计分析

码界西柚

RocketMQ 阿里巴巴‘ Alibaba技术 Apache RocketMQ 1月日更

低代码实现探索(二十九)混合式低代码

零道云-混合式低代码平台

《腾讯云原生在线技术工坊》实践体会

穿过生命散发芬芳

腾讯云 云原生 1月月更 实践体会

ShardingSphere JDBC 分库实现多数据库源

Java 数据库 分库分表 Apache ShardingSphere

(1-19/19)市场和销售分别该怎么干

mtfelix

300天创作 2022Y300P

微信业务架构图 & 学生管理系统架构设计

阿卷

架构实战营

音视频开发学习:HLS 协议详解

赖猫

c++ 音视频 ffmpeg HLS 音视频开发

用Java实现线段树

CRMEB

Linux之cal命令

入门小站

第七周作业

lv

电商秒杀系统架构设计

AHUI

「架构实战营」

关于jiami货币--《香帅中国财富报告》摘录(6/100)

hackstoic

投资

明道云帮助外贸行业实现数字化管理

明道云

22 Prometheus之Docker监控简述

穿过生命散发芬芳

Prometheus 1月月更

微信业务架构分析 & 学生管理系统架构选型

AragornYang

架构训练营 架构实战营

C/C++开发方向如何选择?坚持C++还有意义吗?

赖猫

c++ Linux 服务器

【网络安全】详细记录一道简单面试题的思路和方法

H

网络安全

kali权限提升之本地提权

喀拉峻

网络安全 信息安全 提权

(1-18/18)推播式营销vs.集客式营销

mtfelix

300天创作 2022Y300P

测试工程师的职场发展二三谈

老张

自动化测试 解决方案 职场发展

在线XML转CSV工具

入门小站

工具

使用 React 和 Next.js 构建博客

devpoint

React nextjs 1月月更

PDF 文件如何转成 markdown 格式

汪子熙

markdown PDF pdf.js 1月日更 1月月更

大白话讲解JDK源码系列:从头到尾再讲一遍ThreadLocal

慕枫技术笔记

后端 1月月更

ReactNative进阶(三十):Component、PureComponent 解析

No Silver Bullet

​React Native 1月月更 Component

vue 作者在2022-2-7起宣布 vue3 正式作为默认版本

你?

冬奥探秘:那些隐匿在冬奥中的“绿科技”

脑极体

构建多架构镜像的最佳实践

xcbeyond

Docker arm docker image xcbeyond 1月月更

JavaScript 基本数据类型转换

编程三昧

JavaScript 前端 1月月更

Go len() 函数是如何计算长度的?

宇宙之一粟

Go Go 语言 1月月更

App后端服务,你是选择AWS还是Firebase?_语言 & 开发_Dhananjay Trivedi_InfoQ精选文章