写点什么

在 Saas 发展的黄金时代里,带你从头开始理解 SaaS 的设计

  • 2020-07-21
  • 本文字数:3310 字

    阅读完需:约 11 分钟

在Saas发展的黄金时代里,带你从头开始理解 SaaS的设计

导读:软件即服务(英语:Software as a Service,SaaS),亦可称为 “按需即用软件”(即 “一经要求,即可使用”),它是一种软件交付模式。在这种交付模式中,软件仅需透过互联网,不须经过传统的安装步骤即可使用,软件及其相关的 数据集中托管于云端服务。用户通常使用精简客户端,一般即经由网页浏览器来访问、访问软件即服务。SaaS 最大的特色在于软件本身并没有被下载到用户的硬盘,而是存储在提供商的云端或者服务器。对比传统软件需要花钱购买,下载。软件即服务只需要用户租用软件,在线使用,不仅大大减少了用户购买风险也无需下载软件本身,无设备要求的限制。本文带你从头开始理解 SaaS。

引言

云计算意味着通过互联网而不是计算机的硬盘存储和访问数据和程序。


美国国家标准技术研究所(National Institute of Standards and Technology,NIST)的权威定义是:


云计算是一种实现无处不在、方便、按需网络访问可配置的计算资源(如网络、服务器、存储、应用和服务)的共享池的模式,这些资源可以快速配置和发布,只需最小的管理工作量或服务提供商的互动。


云计算可以分为:


  1. IaaS:云提供商以按次付费的方式提供存储和计算服务。

  2. PaaS:提供了专门面向开发人员的服务和工作流,开发人员可以使用共享的工具、流程和 API 来加速应用程序的开发、测试和部署。

  3. SaaS:通过浏览器在互联网提供应用程序。


什么是 SaaS

软件即服务(SaaS)应用程序通过互联网将软件作为服务交付,从而无需在客户自己的电脑上安装和运行应用程序,并将操作开销降至最低。它使开发人员能够以低成本和更快的上市时间构建可扩展的解决方案。


B2B SaaS 公司开发、托管和维护 SaaS 服务并提供支持,以降低其运营成本。它是下一代产品开发/使用。当信息技术专业人员购买 SaaS 应用程序时,他们最看重的是以下几个标准:


标准 百分比
成本59%
安全性47%
易用性38%
集成30%
客户支持24%
自服务23%
上线时间15%
可扩展性12%
灾难恢复计划12%

SaaS 的好处

  • SaaS 软件可以在世界上任何有互联网的地方访问。

  • 无需本地服务器安装和维护。

  • 订阅通常是“按需付费”,因此比传统软件便宜。

  • 成本效益。

  • 客户可以随时使用软件,无需任何操作开销。

  • 44% 的 SaaS 供应商提供免费试用。

SaaS 的缺点

  • 安全问题:公司的保护健康信息(Protected Health Information,PHI)/安全数据由第三方保存和访问。

  • 有时会延迟功能发布。

  • 是去对应用程序的控制权。

关于 SaaS 市场的事实

  • 2019 年到 2023 年,全球 SaaS 市场预计价值为 603.6 亿美元,在 4 年内复合年增长率为 9%。(来源:Technavio

  • 2015 年到 2017 年,企业使用的 SaaS 应用程序平均数量增长了两倍,从 8 个增至 16 个。(来源:BetterCloud

  • 2018 年,全球 SaaS 工作负载增至 2.06 亿,预计到 2021 年,将达到 3.8 亿。(来源:Statista/Cisco

  • SaaS 市场复合年增长率预测为 18%。(来源:MarketsandMarkets

  • 零售和消费品的增长率最高。(来源:MarketsandMarkets

  • 38% 的公司表示他们几乎完全在 SaaS 上运行。

  • 截止 2020 年 1 月中旬,Saleforce 是美国市值最大的 SaaS 提供商。(来源:Mike Sonders

SaaS 的关键特性和功能

租户

租户可以分为单租户模式、混合租户模式和多租户模式,每种模式都有其优缺点。



  • 单租户是一个架构,每个团队都有专门的服务器和陪她基础设施。

  • 混合租户是单租户模式和多租户模式的组合。

  • 多租户模式是一种业务结构,其中许多组织共享相同的软件来保存和存储数据。

单租户与多租户的优缺点

优点:

单租户 多租户
合规对其灵活
分区环境成本优化
无跨租户影响集中管理
易于进行针对租户的调优简化部署
监控聚合

缺点:

单租户 多租户
费用昂贵有跨租户影响
运营挑战(管理和部署)合规挑战

元数据/配置驱动

一个好的 SaaS 解决方案应该是高效的多租户。可以使用每个租户的元数据来实现多租户。可以为每个特定组件定义元数据。它定义了运行时的应用程序数据、应用程序的基础功能,以及特定租户的数据和自定义(如果有的话)。

弹性

多租户 SaaS 解决方案可以在不同租户之间共享。可伸缩的 SaaS 架构还应该包含组件,这些组件都是无状态的微服务。每个组件都可以相互独立缩放。应用程序应该根据需要进行冬天扩容、缩容。

参考架构

任何 SaaS 解决方案的关键功能都是基础设施、表示、安全性、应用程序和操作。



表示:主要集中在表示层:


  • 用户控件

  • 显示与渲染

  • 报告


安全性:安全性是 SaaS 解决方案的主要功能。主要的应用程序构建注意事项如下:


  • 身份认证和联合身份模式

  • 身份验证和单一登录模式

  • 授权和以角色为基础的访问控制

  • 策略

  • 加密


应用视图:包括在网络上存储和移动数据。


  • 数据库

  • 计算

  • 存储


操作视图:顾名思义,这是 SaaS 最重要的方面。它有助于维护客户的信任,并增加业务。它主要包括:


  • 容错性和可用性

  • 监控与维护

  • 租户的载入

  • 分析

  • 计费与层级管理

  • 备份与恢复

SaaS 应用的最佳实践

  • 自服务:应用程序应该是自服务式的,没有任何工程开销。

  • 个性化:客户可以根据需要改变外观。

  • 多租户:一个软件应用程序的单一实例是为了服务于多个客户。多住户架构方法可以使应用程序提供商和用户都受益。只为多个企业运营一个应用程序实例,对提供商和租户都会带来巨大的成本效益。

  • 集成:SaaS 应用程序应该很容易与其他应用程序集成。

  • 运行性能

  • 安全性和合规性:保证数据安全至关重要。每个租户的机密数据应该是安全且隔离的。

  • 监控:应该自己监视应用程序的停机时间,以及性能问题,因为缓慢的性能会导致用户体验不佳。开发人员需准备好监控工具和流程,以确保应用程序的高可用性。

如何开始


  • 进行市场调查,找出客户需要的功能。

  • 创建功能和技术规范文档。

  • 确定功能的优先级。

  • 创建一个以客户为中心的用户故事,而不是以开发人员为中心的故事。

  • 开发用户体验设计和线框图。

  • 启动 BE 代码的头脑风暴会议。

  • 启动代码和测试套件。

  • 使用最少的功能启动最小化可行产品。

  • 反复测试。

  • 定期听取客户的反馈。如果你的解决方案不能解决客户所面临的主要挑战,那么它就毫无用处。

  • 对于任何新功能的发布,都要重复上述过程。

沃尔玛 SaaS 方法

目前,沃尔玛电商(Walmart eCommerce)为旗下的 walmart.com、ASDA、SAM 等子公司提供 SaaS 服务,遵循 Single/hybrid 租户模式。我们有一个单一的代码库,用于多个租户,所有的功能都是元数据驱动的,这将帮助我们轻松地向多租户模式转变。所有的微服务都是相互隔离的,并且根据用例进行异步和同步通信。虽然单租户的成本效益不是很高,但可以确保在每个租户的基础上解决运营限制。

总结

企业可以利用 SaaS,这可以为他们节省运营成本。精心设计和构建的 SaaS 应用程序可以为供应商和消费者提供双赢的解决方案。


作者介绍:


Adeeti Kaushal,沃尔玛电商技术主管。


原文链接:


https://medium.com/walmartlabs/understanding-saas-from-ground-up-120bf68915d0


2020-07-21 11:364571

评论

发布
暂无评论
发现更多内容

低代码和零代码快速开发崛起,迎来普通人开发软件的时代!

J2PaaS低代码平台

详解 Flink 容器化环境下的 OOM Killed

Apache Flink

flink 流计算

uni-app实现实时消息SDK插件

anyRTC开发者

uni-app 音视频 WebRTC 跨平台 sdk

技术干货丨隐私保护下的迁移算法

华为云开发者联盟

迁移

可用性、可维护性、可靠性有什么区别?

禅道项目管理

DevOps 可用性 质量保障 可靠性

探索压测奥妙

ninetyhe

微服务 分布式系统 压力测试 性能调试

深入分析单例设计模式

Andy

Kubernetes 疑难问题排查 - 10s 延迟

东风微鸣

Kubernetes

大作业一

Geek_83908e

架构师一期

抄答案就是了,两套详细的设计方案,解决头疼的支付掉单问题

楼下小黑哥

支付系统 架构设计

比易宝betBEB平台获278万美元约合1807万元融资

DT极客

架构师训练营第十三周

我是谁

架构师训练营第 1 期

微服务可能失败的11个原因

xcbeyond

微服务 方法论

应用案例| 基于Volcano 的锐天大规模离线高性能计算生产实践

华为云原生团队

云计算 大数据 AI 云原生 批量计算

一周信创舆情观察(2020.12.28~2021.1.3)

统小信uos

Vue 3 组件开发:搭建基于SpreadJS的表格编辑系统(功能拓展)

葡萄城技术团队

Java内存模型精讲

伯阳

Java 后端 多线程 多线程与高并发 Java内存模型

IoT爆发前夕,企业架构要面对哪些变革?

京东科技开发者

物联网

CSS04 - 常用外观属性

Mr.Cactus

html/css

在线自习室场景爆发,在线教育平台用户时间争夺战打响

ZEGO即构

做运维,送你7个常用的服务器资源监控工具

华为云开发者联盟

工具 监控 内存 服务器 系统

Spring 事务,你真的用对了吗(下篇)?

废材姑娘

Java Spring Framework

一文教你学会Hive视图和索引

大数据老哥

大数据 hadoop hive

ROMA Compose:ROMA的新武器

华为云开发者联盟

数据 API ROMA

在NGINX中根据用户真实IP限制访问

东风微鸣

<译文>NGINX 实战手册 - 控制访问

东风微鸣

架构师训练营-第二周作业

Mark

Ansible 新手指南 - 如何批量管理 NGINX

东风微鸣

ansible

企业架构培训感悟

Man

企业架构 中台战略

低成本构建音视频质量监控平台的最佳路径

华为云开发者联盟

数据中台 数据湖 云原生 RTC 华为云

云算力系统APP开发|云算力软件开发

系统开发

在Saas发展的黄金时代里,带你从头开始理解 SaaS的设计_开源_Adeeti Kaushal_InfoQ精选文章