文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-11-30 02:30

关注

延伸阅读,了解 Akamai cloud-computing

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

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

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

我们可以考虑两个简单的例子:文件上传和新用户注册。这两个操作都可以通过通过同步的请求-响应流(例如REST API)发生,但需要发出新请求以更新文件上传状态,或在将新用户的数据插入数据库后通过新请求触发需要执行的下一步操作。假设有一群任务运行程序正在不断地轮询消息,甚至在无线电静默期或者完全与自己无关的时间段内,它们也会不知疲倦地轮询。可想而知,如果使用了按需付费的弹性云计算资源,这种方式会造成巨大浪费。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,用户就只需要支付一个固定并且可预测的费用,而不必担心某些服务的免费额度用完后开始按照执行次数计费。

为何使用无服务器?

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

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

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

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

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

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

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯