合作机构:阿里云 / 腾讯云 / 亚马逊云 / DreamHost / NameSilo / INWX / GODADDY / 百度统计
在这一系列文章中,我们将从架构、设计等不同方面来探讨,在云的可移植性方面,具体都需要考虑哪些细节问题,如何最大限度避免云时代的技术锁定,充分发挥云的灵活性优势。
延伸阅读,了解 Akamai cloud-computing
出海云服务,选择Akamai cloud-computing!
下文将简要探讨事件驱动架构以及无服务器计算。欢迎点击这里回顾云原生和容器技术在云可移植性方面的注意事项;或点击这里回顾微服务架构对云可移植性的重要意义。
事件驱动架构(Event-Driven Architecture,EDA)会对事件或消息做出反应并触发特定操作,但不依赖于直接的同步通信。EDA是异步的,这样组件即可独立运行,从而提高系统在可变工作负载下的响应能力和性能。
我们可以考虑两个简单的例子:文件上传和新用户注册。这两个操作都可以通过通过同步的请求-响应流(例如REST API)发生,但需要发出新请求以更新文件上传状态,或在将新用户的数据插入数据库后通过新请求触发需要执行的下一步操作。假设有一群任务运行程序正在不断地轮询消息,甚至在“无线电静默期”或者完全与自己无关的时间段内,它们也会不知疲倦地轮询。可想而知,如果使用了按需付费的弹性云计算资源,这种方式会造成巨大浪费。EDA通过基于推送的方法解决了这个问题。
事件驱动系统可以按需添加或移除组件从而快速扩展,并对故障获得极高适应性,因为即便某一个组件不可用,系统依然能继续运行。EDA也非常适合实时处理以及海量数据处理,因为组件可以对事件做出反应并在数据到达时就立即开始处理,而不需要等待收到完整的数据集。
EDA同样支持类似无服务器计算这样的应用程序开发模型,这样我们就可以编写可移植,并且与特定供应商无关的代码,从而根据功能、支持的语言、成本等因素灵活选择适合自己的云供应商。函数即服务(Functions-as-a-Service,FaaS)是一种流行的产品,很多云供应商都已提供,用户可以通过这类产品在一个位置管理函数和应用程序基础设施。云供应商作为责任人,主要负责处理底层基础设施,包括服务器的配置、缩放和维护,这样开发者就可以更专注地编写代码。
很多流行的FaaS服务(例如AWS Lambda、Azure Functions以及Google Cloud Functions)就是我们所说的平台原生服务。它们通常会限制用户只能使用特定云提供商的平台,无法轻松迁移至其他平台。Akamai曾多次介绍过,Knative是一种开源、基于Kubernetes的无服务器运行平台,只需几秒钟即可将应用程序从0个副本扩展到N个副本。扩展到0个副本这种能力非常实用,可以让Kubernetes和Knative按需重新分配资源。
我们只需要使用一段代码即可自动扩展资源,因为这种代码可以并行调用多次。从本质上来看,并不建议使用上文提到的平台原生FaaS产品,因为这类服务的费用是不可预测的。但如果通过托管的Kubernetes服务在我们的计算实例上运行Knative,用户就只需要支付一个固定并且可预测的费用,而不必担心某些服务的免费额度用完后开始按照执行次数计费。
正如上文所说,无服务器计算基于事件驱动架构,这意味着函数可以由HTTP请求、文件上传、数据库更新等事件来触发。这有助于简化应用程序架构并改善可扩展性。
无服务器函数的世界也应该是无状态的。函数在不同调用之间不存储任何数据或状态,这保证了函数可以轻松扩展,并且函数故障后可以轻松替换。函数还应当是短暂的,这保证了资源不会被浪费,并且函数能够快速扩展。如果一个函数的任务需要长时间运行,则需评估是否更适合使用持续运行的服务来代替。
无服务器函数同样需要监视并记录日志,这样才能确保函数按照预期运行,同时发现可能存在的任何问题或错误。为此可以使用一些日志聚合器和应用程序性能监视(APM)工具,例如Prometheus和Grafana。另外,别忘了通过身份验证、认证授权、加密等最佳实践措施保护函数,这样不仅可以保护应用程序本身,也能保护敏感数据。在将函数部署到生产环境之前,请进行完善的测试,从而确保函数能够按照预期运行并且不存在漏洞。
无服务器计算极具成本效益,但为了进一步降低成本提高效率,依然需要使用各种成本优化技术,例如函数优化、资源共享以及自动扩展。用户有必要评估自己的工作负载、使用模式以及需求,从而决定对于自己的特定用例来说,无服务器计算是否是一种具备成本效益的方式。另外,对于选择使用的无服务器平台,还需要考虑预期使用模式、性能需求以及定价结构。
这篇文章的内容感觉还行吧?您还可以进一步了解Akamai的云服务方案!别忘了,现在注册可以免费获得价值 100 美元的使用额度,快点自己动手体验本文介绍的功能和服务吧↓↓↓
出海云服务,Akamai是您的不二之选!
欢迎关注Akamai ,第一时间了解高可用的MySQL/MariaDB参考架构,以及丰富的应用程序示例
TOP