Saas软件架构学习

发布时间 2023-09-22 09:34:32作者: 蹇爱黄

接触到Saas架构的软件啦要了解一下啦

what

1.什么是Saas(软件即服务)

从宏观的角度来看,SaaS是一种软件应用程序交付方式,软件提供商集中化托管一个或多个软件应用程序,并通过互联网向租户体用这些软件应用程序。从分类上看,SaaS(软件即服务)也是云计算重要的一部分。目前国内主流的云服务提供商如阿里云、百度云、腾讯云等,为广大用户提供了不同业务需求的云服务,它们大致可以分为以下几类:

基础设施即服务:如CPU、Network、Disk和Memory等
平台即服务:如阿里云服务器和云数据库等
软件即服务:阿里短信、阿里邮箱等
数据即服务:如阿里云对象存储,七牛云存储等
其他软件服务:机器学习、人工智能等
SaaS应用程序的任何更新或者修复漏洞操作都是由软件提供商负责实施和处理的,由于租户是通过互联网获取软件服务,所以租户端无需下载任何的升级包或者修复补丁,是一种开箱即获取最新软件产品的服务方式。 通过对什么是SaaS的介绍,接下来,我们了解一下选择SaaS作为软件架构来设计产品的一些理由。

SaaS 的历史

20 世纪 60 年代,人们将哑终端连接到大型计算机来共享大型计算机的软件,这被称为分时软件交付系统。到 20 世纪 80 年代,随着计算机成本的不断下降,许多企业开始创建自己的本地版本的分时系统,即局域网 (LAN)。但是,企业(而非技术提供商)需要负责提供和管理硬件及网络。

20 世纪 90 年代,随着互联网的出现,提供商开始托管软件并通过互联网为客户提供软件。然而,这种应用服务提供商 (ASP) 模式,同时也是 SaaS 的先驱,具有严重的局限性。举例来说,每一家客户都需要自己的软件版本,这意味着它们必须在用户的计算机上安装一些软件。配置工作需要投入大量时间和成本。最后,ASP 解决方案通常无法高效地收集和汇总数据。

第一款 SaaS 解决方案出现在 20 世纪 90 年代末期,当时 SaaS 这个词刚诞生不久。与 ASP 模式相比,这种新模式具有更高的效率。得益于其多租户架构,单一应用实例可以为多个用户甚至客户提供服务。不再需要在本地安装软件。而且,这种模式还支持收集、汇总和集中管理有价值的应用数据。

why

为什么要用Saas软件
我们将从不同的角度来阐述几个为什么选择SaaS的理由。透过对这些因素的分析,为你是否需要将自己的软件SaaS化提供一定的参考依据。

2.1 消费者角度

获取软件服务的方式足够简单,SaaS也许是迄今为止使用软件最简单的方式之一,租户只需要动动鼠标和键盘,即可在几小时甚至几分钟内获得一个大型的软件服务。相比于传统使用软件的方式,租户省去了研发、部署、运维等一系列繁复的过程,且获得软件的时间和费用成本都大幅度降低。

2.2 商业角度

SaaS可以使用跨地域、跨平台的软件服务。与此同时,软件服务商可以统一对软件进行版本管理,这将带来以下几点好处(包括但不限于):

缩短产品上线时间:多端适配,统一版本,统一更新
降低维护成本:不需要同时维护多个版本的软件实例,运维压力减小
容易升级:由于版本得到有效控制,一次升级,即可覆盖所有租户端

3. SaaS的特性和优势

3.1 简单
SaaS化的产品通过互联网向租户提供软件服务,随着Web技术(如jQuery、Node.js)的进步,Web页面的交互体验度大幅度提升,交互更流畅、更人性化。与传统的桌面应用程序的人机交互效果相差无几。

3.2 经济实惠
SaaS化产品可以为租户提供弹性的付费方案,如按日、按月、按年、按使用人数或者按使用量进行计费,它将给租户提供更经济的使用软件的财务预算表。

3.3、安全
使用SaaS产品无需担心数据安全问题,这好比将钱存入银行一样安全。相较于企业内部部署的软件系统而言,SaaS产品具备更高的安全保障能力,因为软件提供商具有更多软件安全防护的技术资源、人力资源和财政资源。

3.4、兼容性
与传统软件相比、SaaS软件的兼容性更好,它没有传统软件的多本版维护问题和操作系统兼容问题。在SaaS软件中,租户用户在使用软件的过程中,几乎上感觉不到软件发生了改变。当租户用户登录到系统上时,就已经获得了最新版本的软件。

where

Saas软件适合在什么领域进行实施

SaaS产品具有广泛的适应范围,特别是与其他云产品(如IaaS(基础设施即服务)和PaaS(平台即服务))配合使用时这种能力表现尤为突出,例如阿里云之类的云计算技术允许你配置可托管的Web站点、数据库服务器等。你只需要打开浏览器并登录到阿里云控制台,通过操作对应的控制面板,即可获得相关的软件服务。 从理论上讲,SaaS可以将任何的软件SaaS,下面列举一些通用的分类供大家参考:

电子商务类SaaS产品(小样云商,有赞)
Office在线办公类SaaS产品(石墨文档)
社交媒体类SaaS产品(笨鸟社交)
机器学习类SaaS产品
人工智能类SaaS产品
地理位置服务类SaaS产品
数据流和数据检索类SaaS产品
…………

how

1.Saas软件有哪些先天性缺陷

1.1、软件控制权
与企业内部部署的软件不同,由于SaaS软件被击中托管在服务提供商的Web服务器中,所以租户无法控制所有的软件应用程序,SaaS化的软件比企业自行部署的软件获得的控制权更少,租户可操作的自定义控制权极度有限。

1.2、消费者基数小
由于SaaS软件是将一套应用程序共享给一个或者多个租户共同使用,这种共享的消费方式还未被大多数的消费者所接受。同时,受制于市场环境的影响,目前还有大多数的软件还未SaaS化。

1.3、性能瓶颈
共享应用程序必然会带来服务器性能的下降、如计算速度、网络资源、I/O读写等都将面临严峻的考验。在性能方面,企业内部部署的“独享模式”的应用程序比SaaS软件的“共享模式”略胜一筹。

1.4、安全问题
当租户在选择一款SaaS产品时,产品的安全性将会被放置在第一位进行考虑。如数据的隔离、敏感数据的加密、数据访问权限控制、个人隐私等问题。在2018年5月25日,GDPR(General Data Protection Regulation)《通用数据保护条例》出现之后,越来越多的人开始重视数据安全问题。如何最大程度的打消租户的这一顾虑,需要服务提供商加强对自身可信度度的提升,以赢得租户的信赖。

2.Saas软件有哪些核心的组件

2.1、安全组件
在SaaS产品中,系统安全永远是第一位需要考虑的事情,如何保障租户数据的安全,是你首要的事情。这如同银行首选需要保障储户资金安全一样。安全组件就是统一的对SaaS产品进行安全防护,保障系统数据安全。

2.2、数据隔离组件
安全组件解决了用户数据安全可靠的问题,但数据往往还需要解决隐私问题,各企业之间的数据必须相互不可见,即相互隔离。在SaaS产品中,如何识别、区分、隔离个租户的数据时你在实施SaaS软件架构设计时需要考虑的第二个问题。

2.3、可配置组件
尽管SaaS产品在设计之初就考虑了大多数通用的功能,让租户开箱即用,但任然有为数不少的租户需要定制服务自身业务需求的配置项,如UI布局、主题、标识(Logo)等信息。正因为无法抽象出一个完全通用的应用程序,所以在SaaS产品中,你需要提供一个可用于自定义配置的组件。

2.4、可扩展组件
随着SaaS产品业务和租户数量的增长,原有的服务器配置将无法继续满足新的需求,系统性能将会与业务量和用户量成反比。此时,SaaS产品应该具备水平扩展的能力。如通过网络负载均衡其和容器技术,在多个服务器上部署多个软件运行示例并提供相同的软件服务,以此实现水平扩展SaaS产品的整体服务性能。为了实现可扩展能力,就需要SaaS展示层的代码与业务逻辑部分的代码进行分离,两者独立部署。例如使用VUE+微服务构建前后端分离且可水平进行扩展的分布式SaaS应用产品。对于可扩展,还有另外一种方式,即垂直扩展,其做法比较简单,也比较粗暴:通过增加单台服务器的配置,如购买性能更好的CUP、存储更大的内存条、增大带宽等措施,让服务器能够处理更多的用户请求。但此做法对于提升产品性能没有质的改变,且成本很高。

2.5、零停机时间升级产品
以往的软件在升级或者修复Bug是,都需要将运行的程序脱机一段时间,等待升级或修复工作完成后,再重新启动应用程序。而SaaS产品则需要全天候保障服务的可用性。这就需要你考虑如何实现在不重启原有应用程序的情况下,完成应用程序的升级修复工作。

2.6、多租户组件
要将原有产品SaaS化,就必须提供多租户组件,多租户组件是衡量一个应用程序是否具备SaaS服务能力的重要指标之一。SaaS产品需要同时容纳多个租户的数据,同时还需要保证各租户之间的数据不会相互干扰,保证租户中的用户能够按期望索引到正确的数据,多租户组件是你必须要解决的一个问题。其余的组件都将围绕此组件展开各自的业务。

云与Saas有和区别

成本下降和 IT 效率提升推动了第一代云技术应用的发展,而现代 SaaS 应用则提供了一个创新平台,可帮助企业应对数字时代的竞争挑战,例如:

扩展 SaaS 应用功能以支持 Slack 和 Zoom 等协作应用。
小企业的力量。许多小型企业和初创企业正在运用云计算、移动和社交技术打造创新型产品,并以前所未有的速度推向市场。
消费者苛求的时代。在移动和社交工具的支持下,消费者拥有比以往更加丰富的选择和更加充足的信息。
为了应对这些竞争挑战,现代 SaaS 套件可以通过内置分析和整体业务视图来加快创新速度、提供卓越的客户体验以及支持更加明智的业务决策,从而推动企业级创新。

参考:https://zhuanlan.zhihu.com/p/101668538
https://www.oracle.com/cn/applications/what-is-saas/