理解 Serverless:构建全服务应用程序的技巧和资源

本文涉及的产品
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
函数计算FC,每月15万CU 3个月
简介:   本文要点  Serverless 不仅仅是功能即服务(FaaS)。不要担心供应商锁定;接受供应商通过事件集成来提供的功能。开源工具有助于简化复杂应用程序的构建。使用基础设施即代码(Infrastructure as Code,IaC)的解决方案(如 CloudFormation)来定义 Serverless 应用程序并简化 DevOps。强大的监控解决方案可以通过精确的成本管理和评估工具提供函数和集成性能的可视化。  尽管在过去几年中, Serverless 技术已经得到了迅速普及,但是对于 Serverless 解决方案仍然存在许多误解和担忧。供应商锁定、工具、成本管理、冷启动、

  本文要点

  Serverless 不仅仅是功能即服务(FaaS)。不要担心供应商锁定;接受供应商通过事件集成来提供的功能。开源工具有助于简化复杂应用程序的构建。使用基础设施即代码(Infrastructure as Code,IaC)的解决方案(如 CloudFormation)来定义 Serverless 应用程序并简化 DevOps。强大的监控解决方案可以通过精确的成本管理和评估工具提供函数和集成性能的可视化。

  尽管在过去几年中, Serverless 技术已经得到了迅速普及,但是对于 Serverless 解决方案仍然存在许多误解和担忧。供应商锁定、工具、成本管理、冷启动、监控和开发生命周期都是 Serverless 技术相关的热门话题。本文旨在解决其中的一些问题,并分享相关的技巧和资源,以指导 Serverless 新手构建功能强大、灵活且经济高效的 Serverless 应用程序。

  对 Serverless 技术的误解

  其中一个主要的误解是,Serverless 等同于 功能即服务 ( Functions as a Service ,FaaS),因此不值得为此作出特别激进的改变。虽然 AWS Lambda 无疑是 Serverless 崛起的明星之一,并且可以说是 Serverless 架构越来越受欢迎的因素之一,但与 FaaS 相比,Serverless 还有更多功能。

  Serverless 的核心原则是:我们不必担心如何管理基础设施或者扩容缩容,只需为使用的内容付费既可。如果考虑这些因素,那么就有许多可用的服务了,比如 AWS DynamoDB、S3、SNS 或 SQS、Graphcooll、Auth0、Now、Netlify 或 Firebase(还有很多很多)。最终,Serverless 提供了强大的云计算功能,而无需承担管理基础设施或优化容量可伸缩性的负担和责任。这种抽象还意味着基础设施层的安全不再是我们需要关心的问题了,考虑到维护安全标准的难度和复杂性,这是一个非常大的利好。最后但也很重要的是,如果我们不使用它所提供的基础设施,那么就不必为此付费。

  也可以认为 Serverless 是一种“思想状态”——一个人在设计解决方案时所采用的思维方式。避免使用需要维护任何基础设施的方式。通过 Serverless 的方式,我们正在试图将我们投入在项目中的工作时间重新分配到对用户有更直接影响和益处的事情上,比如健壮的业务逻辑、能吸引用户的界面及快速响应、可靠的 API 上。例如,如果我们可以通过支付 Algolia 来避免管理和维护一个自由文本搜索平台,那么这就是我们将要做的。以 Serverless 的方式来构建应用程序可以极大地缩短上市时间,因为我们不再需要担心如何管理复杂的基础设施了。这样可以规避管理基础设施产生的责任和成本,并能集中精力构建客户真正需要的应用程序和服务,这种方式,Patrick Debois 称之为“ 全服务 ”,这个术语已经得到了 Serverless 社区的认可。其次,函数应该被视为将服务绑定在一起的粘合剂,并且可概念化为部署单元(而不是部署整个库或 Web 应用程序),从而允许对应用程序的部署和变更进行非常细粒度的控制。如果不能以这种方式部署函数,那么这可能是一种代码坏味道,表明该函数承担了太多的职责,应该进行重构了。

  在开发云应用程序时,有些人担心供应商锁定。对于 Serverless,这种担心仍然存在,我认为这是源于对 Serverless 真正含义的误解。例如,以我在 AWS 上构建 Serverless 应用程序的经验来看,采用 AWS Lambda 将其他 AWS 服务粘合在一起,是 Serverless 架构强大功能的一部分。这个例子很好地说明了整体是优于局部的。试图避免供应商锁定实际上会导致比我们想要解决的问题还要更严重的问题。使用容器时,在云供应商之间管理自己的抽象层可能会更容易些,但是当使用 Serverless 时,特别是考虑到 Serverless 的成本效益时,这种努力就不值得了。一定要考虑供应商是如何提供设施来暴露服务的;一些专用服务依赖于与其他供应商的强大集成点,并且提供了开箱即用的钩子。从 API 网关端点处指定需要调用的 Lambda 比将请求代理到现有容器或 EC2 实例中要更容易些。Graphcool 使用 Auth0 提供了简单的配置,这比使用自定义标识提供程序也更容易。

  为我们的 Serverless 应用程序选择合适的供应商是一个架构决策问题。我们不应该假定某天再回过头来管理服务器,并以此前提来构建 Serverless 应用程序。选择云供应商与选择使用什么容器或什么数据库来构建应用程序,甚至与用什么语言来编写代码没有什么不同。

  最好考虑下如下几点:

  你需要什么服务以及为什么需要这些服务。云服务供应商提供了哪些不同的服务,以及如何使用你所选择的 FAAS 实现将这些服务粘合在一起。支持哪些编程语言(是动态类型还是静态类型、是编译代码还是解释代码、基准测试、冷启动性能、开源生态系统等)。你的安全要求是什么(SLAS、2FA、OAuth、HTTPS、SSL 等)。如何管理 CI/CD 和软件开发周期。可以利用什么样的基础设施即代码(IaC)解决方案。

  如果你正在对一个现有的应用程序进行扩展并添加了 Serverless 功能,那么这可能会限制你的选择,不过几乎所有 Serverless 技术都提供了某种形式的 API(通过 REST 端点或消息队列),这些 API 提供了一个简单的集成点来将应用程序扩展成可以独立开发的二手手游账号交易平台核心应用程序。选择使用那些提供了易理解的 API 并且具有可靠的文档和强大社区的服务,这样你就不会出错了。很多时候,当谈到 Serverless 技术时,集成的简单性可能是我们关注的关键指标,它可能也是自 2021 年 Lambda 发布以来,AWS 获得成功的最大贡献因素之一。

  在什么情况下使用 serverless 是有益的

  Serverless 几乎可以用在任何地方,我发现现在的使用情况还远远没有发挥出 Serverless 计算的好处。由于 Serverless 技术的存在,云计算的进入门槛现在非常低。如果开发人员有一个想法,但不知道如何管理云基础设施和优化成本,他们完全无需担心是否能找到一个有工程背景的人来帮助他们。如果一家初创公司正在试图构建一个平台,但又担心由此产生的成本,那么他们可以采用 Serverless 的方式轻松实现。

  由于 Serverless 能节约成本且具有可伸缩性,它可以像适用于具有遍布全球数百万用户的 Web 应用程序那样,适用于内部 IT 系统。当谈到计费时,我们可以用美分而不是用欧元(或其他货币)来结算。这是非常强大的。就算是最基础的 AWS EC2 实例(t1.micro)持续开一个月,即使什么都不做(谁还没有忘记关闭的时候呢!),我们也需要花费 15 欧元。为了和 AWS EC2 进行比较,产生相同的成本水平,我们需要在同一时间段内运行一个 1 秒内可达到 300 万次的 512MB 的 Lambda 函数。同样地,如果你不使用这个函数,它就不会产生任何费用。

  由于 Serverless 主要是基于事件的,所以可以将 Serverless 基础设施直接添加到传统系统中。例如,可以使用 AWS S3、Lambda 和 Kinesis 为传统零售系统搭建可以通过 API 网关端点接收数据的分析服务,或者使用 DynamoDB 流和 Algolia 来改进自由文本搜索系统。

  绝大多数的 Serverless 平台都支持多种语言,最常用的有 Python、JavaScript、 C#、Java 和 GO。一般来说,各语言都没有对可使用的库进行限制,因此,我们可以随意选择使用我们最擅长的开源代码库。然而,保持低依赖性仍是个不错的主意,它可以确保函数尽可能地在最佳状态下执行,并能利用 Serverless 应用程序强大的可伸缩性。容器需要装载的包越多,冷启动时间就越长。

  冷启动是指容器、运行时和函数处理程序在使用之前要先初始化。它可能会导致大约 3 秒

相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
目录
相关文章
|
3月前
|
存储 Serverless 数据库
科普文:云计算服务类型IaaS, PaaS, SaaS, BaaS, Faas说明
本文介绍了云计算服务的几种主要类型,包括IaaS(基础设施即服务)、PaaS(平台即服务)、SaaS(软件即服务)、BaaS(后端即服务)和FaaS(函数即服务)。每种服务模式提供了不同的服务层次和功能,从基础设施的提供到应用的开发和运行,再到软件的交付使用,满足了企业和个人用户在不同场景下的需求。文章详细阐述了每种服务模式的特点、优势和缺点,并列举了相应的示例。云计算服务的发展始于21世纪初,随着互联网技术的普及,这些服务模式不断演进,为企业和个人带来了高效、灵活的解决方案。然而,使用这些服务时也需要注意服务的稳定性、数据安全性和成本等问题。
1907 4
|
14天前
|
人工智能 Serverless API
尽享红利,Serverless构建企业AI应用方案与实践
本次课程由阿里云云原生架构师计缘分享,主题为“尽享红利,Serverless构建企业AI应用方案与实践”。课程分为四个部分:1) Serverless技术价值,介绍其发展趋势及优势;2) Serverless函数计算与AI的结合,探讨两者融合的应用场景;3) Serverless函数计算AIGC应用方案,展示具体的技术实现和客户案例;4) 业务初期如何降低使用门槛,提供新用户权益和免费资源。通过这些内容,帮助企业和开发者快速构建高效、低成本的AI应用。
58 12
|
22天前
|
存储 弹性计算 关系型数据库
活动实践 | 告别资源瓶颈,函数计算驱动多媒体文件处理测评
本方案介绍了一种高效处理文件的方法,适用于企业办公和社交媒体应用。通过阿里云的函数计算、对象存储OSS和轻量消息队列,实现文件的异步处理,如格式转换和水印添加,有效减轻了核心应用的负担,提高了业务稳定性和资源利用率。方案包括云服务器ECS、云数据库RDS、OSS存储等组件,支持快速部署和资源清理。
|
1月前
|
运维 Serverless 测试技术
通义灵码 x 函数计算:构建高效开发流程,加速项目交付
本方案基于通义大模型的通义灵码,提供代码生成、补全、优化及单元测试生成等能力,提升编码效率和质量。结合云效和函数计算 FC 进行代码管理、持续集成、部署发布,加速项目交付,为开发者提供智能编码、CI/CD、部署上线体验,加快产品迭代速度。
|
2月前
|
关系型数据库 Serverless 分布式数据库
PolarDB Serverless 模式通过自动扩缩容技术,根据实际工作负载动态调整资源,提高系统灵活性与成本效益
PolarDB Serverless 模式通过自动扩缩容技术,根据实际工作负载动态调整资源,提高系统灵活性与成本效益。用户无需预配高固定资源,仅需为实际使用付费,有效应对流量突变,降低总体成本。示例代码展示了基本数据库操作,强调了合理规划、监控评估及结合其他云服务的重要性,助力企业数字化转型。
33 6
|
2月前
|
弹性计算 人工智能 自然语言处理
魔搭社区与函数计算:高效部署开源大模型的文本生成服务体验
在数字化时代,人工智能技术迅速发展,开源大模型成为重要成果。魔搭社区(ModelScope)作为开源大模型的聚集地,结合阿里云函数计算,提供了一种高效、便捷的部署方式。通过按需付费和弹性伸缩,开发者可以快速部署和使用大模型,享受云计算的便利。本文介绍了魔搭社区与函数计算的结合使用体验,包括环境准备、部署应用、体验使用和资源清理等步骤,并提出了改进建议。
|
3月前
|
存储 消息中间件 人工智能
ApsaraMQ Serverless 能力再升级,事件驱动架构赋能 AI 应用
本文整理自2024年云栖大会阿里云智能集团高级技术专家金吉祥的演讲《ApsaraMQ Serverless 能力再升级,事件驱动架构赋能 AI 应用》。
163 12
|
2月前
|
运维 Serverless 数据处理
Serverless架构通过提供更快的研发交付速度、降低成本、简化运维、优化资源利用、提供自动扩展能力、支持实时数据处理和快速原型开发等优势,为图像处理等计算密集型应用提供了一个高效、灵活且成本效益高的解决方案。
Serverless架构通过提供更快的研发交付速度、降低成本、简化运维、优化资源利用、提供自动扩展能力、支持实时数据处理和快速原型开发等优势,为图像处理等计算密集型应用提供了一个高效、灵活且成本效益高的解决方案。
101 1
|
3月前
|
机器学习/深度学习 监控 物联网
函数即服务(FaaS)
函数即服务(FaaS)
117 6
|
2月前
|
运维 监控 Serverless
Serverless架构在图像处理等计算密集型应用中展现了显著的优势
Serverless架构在图像处理等计算密集型应用中展现了显著的优势
40 1

相关产品

  • 函数计算