Serverless 工程实践 | 细数 Serverless 的配套服务

本文涉及的产品
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
函数计算FC,每月15万CU 3个月
性能测试 PTS,5000VUM额度
简介: 上文说到云计算的十余年发展让整个互联网行业发生了翻天覆地的变化,Serverless 作为云计算的产物,或者说是云计算在某个时代的表现,被很多人认为是真正意义上的云计算,关于“Serverless 是什么”这个问题,其实是可以通过不同角度来分析的。

作者 | 刘宇


前言


上文说到云计算的十余年发展让整个互联网行业发生了翻天覆地的变化,Serverless 作为云计算的产物,或者说是云计算在某个时代的表现,被很多人认为是真正意义上的云计算,关于“Serverless 是什么”这个问题,其实是可以通过不同角度来分析的。


Martin Fowler 在 “Serverless Architectures” 一文中从 Serverless 组成角度给出了 Serverless 的定义,他认为 Serverless 实际上是 BaaS 与 FaaS 的组合,并针对 BaaS 和 FaaS 进行了详细的描述。


Serverless 最早用于描述那些大部分或者完全依赖于第三方(云端)应用或服务来管理服务器端逻辑和状态的应用,这些应用通常是富客户端应用(单页应用或者移动端App),建立在云服务生态之上,包括数据库(Parse、Firebase)、账号系统(Auth0、AWS Cognito)等。这些服务最早被称为 Baas(Backend as a Service,后端即服务)。


Serverless 还可以指这种情况:应用的一部分服务端逻辑依然由开发者完成,但是和传统架构不同,它运行在一个无状态的计算容器中,由事件驱动,生命周期很短(甚至只有一次调用),完全由第三方管理。这种情况被称为 FaaS(Functions as a service,函数即服务)。AWS Lambda 是目前的热门 FaaS 实现之一。


通过 Martin Fowler 的描述可以总结出 FaaS、BaaS 以及 Serverless 之间的关系为下图所示。


image.png

image.gifServerless 架构的组成


从 Serverless 的结构上来看,Serverless = FaaS + BaaS 是一个被普遍认可的概念;从 Serverless 的特性上来看,Serverless 运行在无状态的计算容器中,由事件触发,并且拥有弹性伸缩以及按量付费等能力,让使用者不用花费更多的精力在服务器上,而是更加关注业务本身。


image.png

image.gif不同角度上的 Serverless 的定义




Serverless 工作流程


在实际生产中,Serverless 架构通常都是 FaaS 与 BaaS 的结合,并且具备弹性伸缩和按量付费的特性。


当开发者想要开发一个项目的时候:

  • 通常只需要根据 FaaS 提供商所提供的 Runtime,选择一个熟悉的编程语言,然后进行项目开发、测试(图中步骤 1)
  • 完成之后将代码上传到FaaS平台(图中步骤 2)


  • 上传完成之后,只需要通过 API/SDK;或者一些云端的事件源(图中步骤 3)
  • 触发上传到 FaaS 平台的函数,FaaS 平台就会根据触发的并发度等弹性执行对应的函数(图中步骤 4)
  • 最后用户可以根据实际资源使用量进行按量付费(图中步骤 5)


image.png

Serverless 工作流程


我们来看一个 Web 应用的例子。通常情况下一些 Web 应用都是传统的三层 C/S 架构,例如一个常见的电子商务应用,假设它的服务端用 Java,客户端用 HTML/JavaScript。

image.png

image.gif传统 Web 应用三层 C/S 架构


在这个架构下,服务端仅为云服务器,其承载了大量业务功能和业务逻辑,例如,系统中的大部分逻辑(身份验证、页面导航、搜索、交易等)都在服务端实现。把它改造成 Serverless 应用形态。


image.png

image.gifServerless 应用形态简图


在 Serverless 应用形态下,移除了最初应用中的身份验证逻辑,换用一个第三方的 BaaS 服务(上图中步骤 1);允许客户端直接访问一部分数据库内容,这部分数据完全由第三方托管,会用一些安全配置来管理客户端访问相应数据的权限(上图中步骤 2);前面两点已经隐含了非常重要的第三点:先前服务端的部分逻辑已经转移到了客户端,如保持用户 Session、理解应用的 UX 结构、获取数据并渲染出用户界面等。


客户端实际上已经在逐步演变为单页应用(上图中步骤 3);还有一些任务需要保留在服务器上,比如繁重的计算任务或者需要访问大量数据的操作。这里以“搜索”为例,搜索功能可以从持续运行的服务端中拆分出来,以 FaaS 的方式实现,从 API 网关(后文做详细解释)接收请求并返回响应。这个服务端函数可以和客户端一样,从同一个数据库读取产品数据。原始的服务端是用 Java 写的,而 AWS Lambda(假定用的这家 FaaS 平台)也支持 Java,那么原先的搜索代码略作修改就能实现这个搜索函数(上图中步骤 4);还可以把“购买”功能改写为另一个 FaaS函数,出于安全考虑,它需要在服务端而非客户端实现。它同样经由API网关暴露给外部使用(上图中步骤 5)。


在整个项目中,Serverless 用户实际关心的也就只剩下函数中的业务逻辑,至于身份验证逻辑、API 网关以及数据库等原先在服务端的一些产品/服务统统交给云厂商提供。在整个项目开发、上线以及维护的过程中,用户并不需要关注服务器层面的维护,也无须为流量的波峰波谷进行运维资源的投入,这一切的安全性、弹性能力以及运维工作都交给云厂商来统一处理/调度,用户所需要关注的就是自己的业务代码是否符合自己的业务要求,同时在 Serverless 架构下,用户也无需为资源闲置进行额外的支出,Serverless 架构的按量付费模型以及弹性伸缩能力、服务端低运维/免运维能力,可以让 Serverless 用户的资源成本、人力成本、整体研发效能得到大幅度提升,让项目的性能、安全性、稳定性得到极大的保障。


Serverless 的配套服务


1、开发者工具


Serverless 开发者工具包括命令行工具、编辑器插件以及其他工具。

一般情况下,命令行工具有厂商一方工具和开源建设的三方工具两种,例如 AWS Lambda 的 SAM CLI、阿里云函数计算的 Funcraft 等就是典型的一方工具。这类工具的特点是和厂商、产品的匹配度非常高,一些特性的支持比较迅速,缺点是比较保守。Serverless Devs、Serverless Framework 就是典型的三方工具,这两个工具都支持 AWS Lambda、阿里云函数计算、腾讯云云函数等云厂商的 FaaS 产品。


从客户端表现上来看,其都是 Serverless 开发者工具,都是组件化的命令行工具,也都支持多云;从形态上来看,Serverless Framework 更注重部署与运维方向, Serverless Devs 更注重 Serverless 应用的全生命周期。同时,Serverless Devs 相对 Serverless Framework 而言,增加了可视化界面。


image.png

image.gifServerless Devs GUI 首页


如图所示,通过该界面,用户可以快速地部署应用。

image.png

Serverless Devs GUI 可视化 Yaml 编辑页


用户可以快速地管理云上 Serverless 相关资源,如图所示。


image.png

Serverless Devs GUI 项目管理页


Azure Functions 也提供了 Visual Studio Code 插件,如下图所示。Visual Studio 中的 Azure Functions 项目模板可用于创建项目,创建的项目可发布到 Azure 中的函数应用中。用户可使用函数应用将函数分组为一个逻辑单元,以便于管理、部署和共享资源。

image.png

image.gifAzure Functions 提供的 VSCode 插件


阿里云在开发者工具层面提供了 VSCode 插件,如图所示。

image.png


同时,阿里云函数计算还提供了 Cloud Toolkit 工具,实现了在本地 Jet Brains IDE 中运行、下载云端函数,创建、上传本地函数。以 IntelliJ IDEA 为例,其函数管理界面如下图所示。


image.png

阿里云函数计算 VSCode 插件函数管理界面


2、Serverless Workflow


Serverless Workflow(Serverless 工作流)是一个用来协调多个分布式任务执行的全托管云服务。


如图所示,在 Serverless 工作流中,用户可以用顺序、分支、并行等方式来编排分布式任务。Serverless 工作流会按照设定好的步骤可靠地协调任务,跟踪每个任务的状态转换,并在必要时执行用户定义的重试逻辑,以确保工作流顺利完成。


Serverless 工作流通过提供日志记录和审计来监视任务的执行,方便用户轻松地诊断和调试应用。Serverless 工作流简化了开发和运行业务流程所需要的任务协调、状态管理以及错误处理等烦琐的工作,让用户聚焦业务逻辑开发。


image.png

image.gifServerless 工作流示例


Serverless 工作流可以协调分布式组件编排不同基础架构、不同网络、不同语言编写的应用,抹平混合云、专有云过渡到公共云或者从单体架构演进到微服务架构的落差。Serverless 工作流提供了丰富的控制逻辑,例如顺序、选择、并行等,让用户以更少的代码实现 复杂的业务逻辑。Serverless 工作流为用户管理流程状态,提供内置检查点和回放能力,以确保应用程序按照预期逐步执行。错误重试和捕获可以让用户灵活地处理错误。Serverless 工作流根据实际执行步骤转换个数收费,执行结束不再收费。Serverless 工作流自动扩展,让用户免于管理硬件预算和扩展。


Serverless 应用的可观测性


Serverless 应用的可观测性是被很多用户所关注的。可观测性是通过外部表现判断系统内部状态来衡量的。在应用开发中,可观测性帮助用户判断系统内部的健康状况,在系统出现问题时,帮助用户定位问题、排查问题、分析问题;在系统平稳运行时,帮助用户评估风险,预测可能出现的问题。在 Serverless 应用开发中,如果观察到函数的并发度持续升高,很可能是业务推广团队努力工作使业务规模迅速扩张。为了避免达到并发度限制阈值,开发者就需要提前提升并发度。以阿里云函数计算为例,阿里云函数计算在可观测性层面提供了多种维度,包括 Logging、Metric 以及 Tracing 等。


image.png

函数计算可观测性整体图表


在控制台监控中心,我们可以查看整体的 Metric、服务级 Metric 以及每个函数的 Metric。除此之外,我们还可以看到当前函数的请求记录。


image.png

函数计算可观测性函数请求记录


根据不同的请求记录,可以查看到函数的详细信息,如图所示。


image.png

函数计算可观测性请求级记录详细信息


除了在控制台的监控中心处可以查看到函数的日志等信息,我们在函数详情页面也可以看到函数的详细日志信息。


image.png

函数计算日志查看


Tracing 相关信息如图所示。

image.png

函数计算可观测性 Tracing 相关信息



关于作者:


image.png

刘宇(江昱)国防科技大学电子信息专业在读博士,阿里云 Serverless 产品经理,阿里云 Serverless 云布道师,CIO 学院特聘讲师。


新书推荐


image.png


本书会通过多个开源项目、多个云厂商的多款云产品,以及多种途径向读者介绍什么是 Serverless 架构、如何上手 Serverless 架构、不同领域中 Serverless 架构的应用以及如何从零开发一个 Serverless 应用等。本书可以帮助读者将 Serverless 架构融入到自己所在的领域,把 Serverless 项目真实落地,获得 Serverless 架构带来的技术红利。


立刻点击购买:

http://product.m.dangdang.com/29250860.html?unionid=P-113341856m-:-dd_1

相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
3月前
|
存储 Serverless 数据库
科普文:云计算服务类型IaaS, PaaS, SaaS, BaaS, Faas说明
本文介绍了云计算服务的几种主要类型,包括IaaS(基础设施即服务)、PaaS(平台即服务)、SaaS(软件即服务)、BaaS(后端即服务)和FaaS(函数即服务)。每种服务模式提供了不同的服务层次和功能,从基础设施的提供到应用的开发和运行,再到软件的交付使用,满足了企业和个人用户在不同场景下的需求。文章详细阐述了每种服务模式的特点、优势和缺点,并列举了相应的示例。云计算服务的发展始于21世纪初,随着互联网技术的普及,这些服务模式不断演进,为企业和个人带来了高效、灵活的解决方案。然而,使用这些服务时也需要注意服务的稳定性、数据安全性和成本等问题。
2349 4
|
22天前
|
负载均衡 Serverless 持续交付
云端问道9期实践教学-省心省钱的云上Serverless高可用架构
详细介绍了云上Serverless高可用架构的一键部署流程
48 10
|
1月前
|
人工智能 Serverless API
尽享红利,Serverless构建企业AI应用方案与实践
本次课程由阿里云云原生架构师计缘分享,主题为“尽享红利,Serverless构建企业AI应用方案与实践”。课程分为四个部分:1) Serverless技术价值,介绍其发展趋势及优势;2) Serverless函数计算与AI的结合,探讨两者融合的应用场景;3) Serverless函数计算AIGC应用方案,展示具体的技术实现和客户案例;4) 业务初期如何降低使用门槛,提供新用户权益和免费资源。通过这些内容,帮助企业和开发者快速构建高效、低成本的AI应用。
76 12
|
1月前
|
Serverless 开发工具 开发者
活动实践 | 西游再现,函数计算一键部署 Flux 超写实文生图模型部署
这些图片展示了阿里巴巴云开发者生态的多个方面,包括开发工具、技术文档、社区交流、培训认证等内容,旨在为开发者提供全方位的支持和服务。
|
1月前
|
存储 弹性计算 关系型数据库
活动实践 | 告别资源瓶颈,函数计算驱动多媒体文件处理测评
本方案介绍了一种高效处理文件的方法,适用于企业办公和社交媒体应用。通过阿里云的函数计算、对象存储OSS和轻量消息队列,实现文件的异步处理,如格式转换和水印添加,有效减轻了核心应用的负担,提高了业务稳定性和资源利用率。方案包括云服务器ECS、云数据库RDS、OSS存储等组件,支持快速部署和资源清理。
|
2月前
|
监控 Serverless 云计算
探索Serverless架构:开发实践与优化策略
本文深入探讨了Serverless架构的核心概念、开发实践及优化策略。Serverless让开发者无需管理服务器即可运行代码,具有成本效益、高可扩展性和提升开发效率等优势。文章还详细介绍了函数设计、安全性、监控及性能和成本优化的最佳实践。
|
2月前
|
弹性计算 算法 搜索推荐
活动实践 | 通过函数计算部署ComfyUI以实现一个AIGC图像生成系统
ComfyUI是基于节点工作流稳定扩散算法的新一代WebUI,支持高质量图像生成。用户可通过阿里云函数计算快速部署ComfyUI应用模板,实现个性化定制与高效服务。首次生成图像因冷启动需稍长时间,之后将显著加速。此外,ComfyUI允许自定义模型和插件,满足多样化创作需求。
|
2月前
|
弹性计算 自然语言处理 搜索推荐
活动实践 | 基于函数计算部署GPT-Sovits模型实现语音生成
通过阿里云函数计算部署GPT-Sovits模型,可快速实现个性化声音的文本转语音服务。仅需少量声音样本,即可生成高度仿真的语音。用户无需关注服务器维护与环境配置,享受按量付费及弹性伸缩的优势,轻松部署并体验高质量的语音合成服务。
|
2月前
|
弹性计算 人工智能 自然语言处理
魔搭社区与函数计算:高效部署开源大模型的文本生成服务体验
在数字化时代,人工智能技术迅速发展,开源大模型成为重要成果。魔搭社区(ModelScope)作为开源大模型的聚集地,结合阿里云函数计算,提供了一种高效、便捷的部署方式。通过按需付费和弹性伸缩,开发者可以快速部署和使用大模型,享受云计算的便利。本文介绍了魔搭社区与函数计算的结合使用体验,包括环境准备、部署应用、体验使用和资源清理等步骤,并提出了改进建议。
|
3月前
|
机器学习/深度学习 监控 物联网
函数即服务(FaaS)
函数即服务(FaaS)
148 6

相关产品

  • 函数计算