有关云可移植性的三个考量:三事件驱动架构(EDA)和无服务器计算​

在这一系列文章中,我们将从架构、设计等不同方面来探讨,在云的可移植性方面,具体都需要考虑哪些细节问题,如何最大限度避免云时代的技术锁定,充分发挥云的灵活性优势。

延伸阅读,了解 Akamai cloud-computing

出海云服务,选择Akamai cloud-computing

下文将简要探讨事件驱动架构以及无服务器计算。欢迎点击这里回顾云原生和容器技术在云可移植性方面的注意事项;或点击这里回顾微服务架构对云可移植性的重要意义。

事件驱动架构(Event-Driven ArchitectureEDA)会对事件或消息做出反应并触发特定操作,但不依赖于直接的同步通信。EDA是异步的,这样组件即可独立运行,从而提高系统在可变工作负载下的响应能力和性能。

我们可以考虑两个简单的例子:文件上传和新用户注册。这两个操作都可以通过通过同步的请求响应流(例如REST API)发生,但需要发出新请求以更新文件上传状态,或在将新用户的数据插入数据库后通过新请求触发需要执行的下一步操作。假设有一群任务运行程序正在不断地轮询消息,甚至在无线电静默期或者完全与自己无关的时间段内,它们也会不知疲倦地轮询。可想而知,如果使用了按需付费的弹性云计算资源,这种方式会造成巨大浪费。EDA通过基于推送的方法解决了这个问题。

事件驱动系统可以按需添加或移除组件从而快速扩展,并对故障获得极高适应性,因为即便某一个组件不可用,系统依然能继续运行。EDA也非常适合实时处理以及海量数据处理,因为组件可以对事件做出反应并在数据到达时就立即开始处理,而不需要等待收到完整的数据集。

为何要使用EDA

  • 增强系统灵活性:事件驱动架构松散耦合的特性使得我们可以轻松修改、添加或移除组件而不影响整体系统,从而让系统能够适应不断变化的需求。
  • 提高可扩展性:EDA支持非常方便的水平扩展,借此,企业可以根据需要添加更多组件或服务实例,从而应对增加的工作负载或流量。
  • 提高系统弹性:EDA的异步通信以及解耦的组件有助于提高容错能力,因为一个组件的故障并不一定导致整个系统中断。
  • 实时处理能力:EDA能实时处理大量数据和复杂的事件模式,因此很适合需要立即获得洞察力或对快速变化的情况快速做出反应的业务场景。
  • 优化资源使用:通过仅在事件发生时对其做出反应,EDA有助于优化资源利用率并减少对持续运行流程的需求,从而帮助企业节约成本,提高效率。

云原生无服务器计算

EDA同样支持类似无服务器计算这样的应用程序开发模型,这样我们就可以编写可移植,并且与特定供应商无关的代码,从而根据功能、支持的语言、成本等因素灵活选择适合自己的云供应商。函数即服务(Functions-as-a-ServiceFaaS)是一种流行的产品,很多云供应商都已提供,用户可以通过这类产品在一个位置管理函数和应用程序基础设施。云供应商作为责任人,主要负责处理底层基础设施,包括服务器的配置、缩放和维护,这样开发者就可以更专注地编写代码。

很多流行的FaaS服务(例如AWS LambdaAzure Functions以及Google Cloud Functions)就是我们所说的平台原生服务。它们通常会限制用户只能使用特定云提供商的平台,无法轻松迁移至其他平台。Akamai曾多次介绍过,Knative是一种开源、基于Kubernetes的无服务器运行平台,只需几秒钟即可将应用程序从0个副本扩展到N个副本。扩展到0个副本这种能力非常实用,可以让KubernetesKnative按需重新分配资源。

我们只需要使用一段代码即可自动扩展资源,因为这种代码可以并行调用多次。从本质上来看,并不建议使用上文提到的平台原生FaaS产品,因为这类服务的费用是不可预测的。但如果通过托管的Kubernetes服务在我们的计算实例上运行Knative,用户就只需要支付一个固定并且可预测的费用,而不必担心某些服务的免费额度用完后开始按照执行次数计费。

为何使用无服务器?

  • 成本效率:无服务器计算按用量付费的定价模型有助于节约成本,企业只需要为自己实际使用的计算时间付费,无需提前分配资源。
  • 提高可扩展性:无服务器计算可以自动扩展资源以满足需求,确保应用程序可以顺利处理激增的工作负载而无需人工介入或停机。
  • 降低运维开销:对于无服务器计算,云提供商负责管理底层基础设施,这样IT团队就能更专注于应用程序的开发、创新,以及其他战略性活动。
  • 更快的上市时间:无服务器计算简化的开发和部署流程有助于企业更快速发布新功能、更新以及Bug修复,从而增强自己的竞争优势。
  • 灵活性和适应性:无服务器计算使得企业能够使用各种编程语言和技术构建并部署应用程序,从而更易于适应需求的变化或按需融入新技术。

正如上文所说,无服务器计算基于事件驱动架构,这意味着函数可以由HTTP请求、文件上传、数据库更新等事件来触发。这有助于简化应用程序架构并改善可扩展性。

无服务器函数的世界也应该是无状态的。函数在不同调用之间不存储任何数据或状态,这保证了函数可以轻松扩展,并且函数故障后可以轻松替换。函数还应当是短暂的,这保证了资源不会被浪费,并且函数能够快速扩展。如果一个函数的任务需要长时间运行,则需评估是否更适合使用持续运行的服务来代替。

无服务器函数同样需要监视并记录日志,这样才能确保函数按照预期运行,同时发现可能存在的任何问题或错误。为此可以使用一些日志聚合器和应用程序性能监视(APM)工具,例如PrometheusGrafana。另外,别忘了通过身份验证、认证授权、加密等最佳实践措施保护函数,这样不仅可以保护应用程序本身,也能保护敏感数据。在将函数部署到生产环境之前,请进行完善的测试,从而确保函数能够按照预期运行并且不存在漏洞。

无服务器计算极具成本效益,但为了进一步降低成本提高效率,依然需要使用各种成本优化技术,例如函数优化、资源共享以及自动扩展。用户有必要评估自己的工作负载、使用模式以及需求,从而决定对于自己的特定用例来说,无服务器计算是否是一种具备成本效益的方式。另外,对于选择使用的无服务器平台,还需要考虑预期使用模式、性能需求以及定价结构。

这篇文章的内容感觉还行吧?您还可以进一步了解Akamai的云服务方案!别忘了,现在注册可以免费获得价值 100 美元的使用额度,快点自己动手体验本文介绍的功能和服务吧↓↓↓

出海云服务,Akamai是您的不二之选!

欢迎关注Akamai ,第一时间了解高可用的MySQL/MariaDB参考架构,以及丰富的应用程序示例

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/290416.html<

(0)
运维的头像运维
上一篇2025-05-19 05:18
下一篇 2025-05-19 05:19

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注