天天看点

入门篇:函数计算的基本概念和通用场景概述Serverless的基本概念Serverless和函数计算的区别函数计算的典型用户场景

4月26日,阿里云正式推出了函数计算这个微服务产品,在此之前serverless的概念被炒的极其火热,仿佛大家要欢天喜地进入了微服务的狂欢阶段,不过光有概念很容易晕,今天我带大家一起来细化一下serverless的基本概念、serverless跟传统it架构的对比、serverless和函数计算的区别,以及函数计算最典型场景都有哪些。

serverless是一种基于互联网的技术架构理念,应用逻辑并非全部在服务端实现,而是采用faas(function as a service)架构,通过功能组合来实现应用程序逻辑。同时,serverless架构能够让开发者在构建应用的过程中无需关注计算资源的获取和运维,由平台来按需分配计算资源并保证应用执行的sla,按照调用次数进行计费,有效的节省应用成本。 

我画个简单对比图来对比传统it架构和serverless的真正区别在哪里:

入门篇:函数计算的基本概念和通用场景概述Serverless的基本概念Serverless和函数计算的区别函数计算的典型用户场景

在该架构中,我们在云服务器上是部署了web容器来解析web图片处理应用,用户通过手机上的app上传图片,应用程序对图片进行定制,例如按用户属性分类、按区域分类,审核鉴黄图片、以及建立图片索引等个性化数据处理后,把图片存储到云存储中,用户通过最近节点cdn可以读取经过处理的图片,达到图片分享的功能。

当应用上线后,在营销推广后业务量达到高峰值就要考虑云服务器的负载均衡问题,<b>架构就开始演变成集群模式,详见集群架构图:</b>

<b></b>

入门篇:函数计算的基本概念和通用场景概述Serverless的基本概念Serverless和函数计算的区别函数计算的典型用户场景

在这个架构中,我们需要做如下事情:

<b>1.</b><b>管理云服务器。我们要关心cpu</b><b>数量、内存大小、ip</b><b>地址等等系统级的配置。</b>

<b>2.</b><b>管理云服务器操作系统,为部署容器设置访问策略,操作系统版本以及容器安全补丁也不能忽视,否则竞争对手可能雇佣黑客来攻击我们的系统。</b>

<b>3.</b><b>配置整套环境的弹性扩容的策略,应对高峰期突发访问量。</b>

<b>4.</b><b>需要配置云存储、cdn</b><b>。</b>

<b>5.</b><b>编写web</b><b>图片处理应用。</b>

<b>serverless(函数计算)架构图:</b><b></b>

如果使用函数计算,用户可以设置云存储的触发器(putobject事件),当用户上传图片到oss会立即触发一个函数来处理图片,同样当业务访问量是峰值的时候,函数计算会自动扩容来支撑整个业务量的处理。处理后的数据回传到oss中,其他用户通过cdn可以访问被处理后的图片。

其中架构图如下:<b></b>

入门篇:函数计算的基本概念和通用场景概述Serverless的基本概念Serverless和函数计算的区别函数计算的典型用户场景

我随手摘录网文上介绍的serverless的优势:

<b>1</b><b>、节约使用成本</b>

在业务突发性极高的场景下,系统为了应对业务高峰,必须构建能够应对峰值需求的系统,这个系统在大部分时间是空闲的,这就导致了严重的资源浪费和成本上升。在serverless架构下,服务将根据用户的调用次数进行计费,节省了使用成本,同时,用户能够通过共享网络、硬盘、cpu等计算资源,在业务高峰期通过弹性扩容方式有效的应对业务峰值,在业务波谷期将资源分享给其他用户,有效的节约了成本

<b>2</b><b>、简化设备运维</b>

在原有的it体系中,开发团队即需要维护应用程序,同时还要维护硬件基础设施;serverless架构中,开发人员面对的将是第三方开发或自定义的api 和url,底层硬件对于开发人员透明化了,技术团队无需再关注运维工作,能够更加专注于应用系统开发

<b>3、</b><b>提升可维护性</b>

serverless架构中,应用程序将调用多种第三方功能服务,组成最终的应用逻辑。

例如登录鉴权服务,云数据库服务等第三方服务在安全性、可用性、性能方面都进行了大量优化,开发团队直接集成第三方的服务,能够有效的降低开发成本,同时使得应用的运维过程变得更加清晰,有效的提升了应用的可维护性。<b></b>

阿里云的函数计算(function compute)是基于serverless这种理论框架下推出弹性海量计算平台,是serverless的一种实现,函数计算主打的旋律是轻、快、有弹性,从一定意义上来看也可以认为函数计算就是serverless的一个paas平台。下面来大致看看函数计算的主要组成部分和基本概念:

<b>包含关系:</b>

入门篇:函数计算的基本概念和通用场景概述Serverless的基本概念Serverless和函数计算的区别函数计算的典型用户场景

<b>函数概念解释:</b>

1、service有两层意义,一层可以按照业务属性来划分不同的服务专区,方便用户做分类识别,另外一层对执行单元的授权、配置专属日志等,都在service进行配置。

2、一个service可以设置50组function,一个function可以设置10个trigger,一个trigger只能被一个event定义。

3、function是函数计算最小的执行单位,是核心代码的执行区域。

阿里云函数计算目前是通过事件来触发函数的执行,处理的函数符合执行无状态、执行幂等性等特点。一一来讲解这些典型用户场景:

<b>基于事件触发:</b>

<b>1、iot</b><b>应用</b>:设备端通过函数计算来订阅天气信息和空气质量,设备和设备之间无依赖,执行过程中无需记录状态,获取到第三方数据即可返回。

<b>2、web</b><b>应用</b>:某web网站在用户注册成功后,会发一封欢迎邮件,通过函数计算把邮件内容定制成模板,每次触发,每次执行都是幂等无状态。

<b>3、图片处理</b>:基于oss的事件触发,当用户上传的图片转入到某bucket中后,自动触发函数岁图片进行可定制化处理

<b>4、音频转换文字处理:</b>当用户通过语音来发出某些指令的时候,可以通过函数计算来触发阿里云的et公开api获取到音频转换成文字的方式。

<b>基于云产品场景的触发:</b>

<b>1、</b><b>oss</b><b>(云存储)应用:</b>

<b>a、图片处理:</b>监控bucket、object事件(put、delete、get、head等)触发用户对函数运行,比如图片的转码、水印或者鉴黄后的图片分发到多个区域的bucket等。

<b>b、日志处理:</b>通过函数计算事件触发,把存放的不同区域的bucket下的日志文件进行汇总,分解,计算,并把计算结果通过回调函数通知invoke程序。

<b>2、</b><b>apigateway</b><b>的应用:</b>

<b>a、</b><b>api</b><b>数据商,</b>通过apigateway连接函数计算,并从阿里云市场中获取到的数据,例如天气、股票、空气质量等进行数据分析和数据清洗后,通过回调函数返回运算过的数据,达到自由定制的功能。同时享受apigateway高附加值,例如流控、鉴权、监控的功能。

详见下图架构:

入门篇:函数计算的基本概念和通用场景概述Serverless的基本概念Serverless和函数计算的区别函数计算的典型用户场景

<b>b、</b><b>api</b><b>代理商:</b>通过apigateway分发标准化的api接口,建立自己的生态系统,在apigateway背后调用函数计算把后端对资源和跨产品的能力包装起来(对图片、ai、数据等),形成统一解决方案,例如对空气质量的定制,对多个来源,ios,android,web,物联网hub都统一输出。

以上就是对函数计算产品的综述,拥有最新、最辣、最火爆的技术,永远是开发者的终极追求,套用广告词,谁用谁知道!

继续阅读