关于事件驱动:事件总线-函数计算构建云上最佳事件驱动架构应用
作者 | 史明伟(世如) 间隔阿里云事件总线(EventBridge)和 Serverless 函数计算(Function Compute,FC)发表全面深度集成曾经过来一年。站在零碎元数据互通,产品深度集成的肩膀上,这一年咱们又走过了哪些历程? 从事件总线到事件流,从基于 CloudEvents 的事件总线触发到更具个性化的事件流触发,函数计算已成为事件总线生态不可或缺的重要组成部分,承载了 EventBridge 零碎架构中越来越多的角色,事件流基础架构的函数 Transform,基于函数计算的多种上游 Sink Connector 投递指标反对,函数作为 EventBridge 端点 API Destination;基于事件总线对立,规范的事件通道能力,和基于函数计算麻利、轻量、弹性的计算能力,咱们将又一次起航摸索云上事件驱动架构的最佳实际。 本文主题围绕事件总线+函数计算,构建云上最佳事件驱动架构利用。心愿通过上面的分享,帮忙大家深刻了解 Serverless 函数计算、EventBridge 事件总线对于构建云上事件驱动架构利用的价值和背地的逻辑、 为什么函数计算是云上事件驱动服务最佳实际?为什么咱们如此须要事件总线服务?随同着这些谜题的解开,最初,让咱们一起理解利用于理论生产的一些 Serverless 事件驱动客户案例。 事件驱动架构的实质 Back to the Nature of Event-Driven大家可能会纳闷,事件驱动妇孺皆知,为什么咱们又要从新探讨事件驱动呢?我想这也正是咱们须要探讨它的起因,回归实质,从新起航。 事件驱动可能是一个比拟宽泛的概念,而本文聚焦事件驱动架构的探讨,事件驱动架构作为一种软件设计模式,确实不是一个新的概念,随同着计算机软件架构的演进,它曾经存在了一段很久的工夫,大家对它的探讨也从未进行过,当咱们须要从新探讨一个曾经存在的概念的时候,我想咱们有必要从新回到它最开始的定义,一起摸索那些实质的货色,重新认识它。 下面的这些内容是我从相干的一些材料上摘录的对于事件驱动架构的一些形容,“abstract”,“simple”,“asynchronous”,“message-driven” 这些具备代表性的词汇很好的给予事件驱动架构一个宏观的形容;从事件驱动架构的抽象概念,到它简洁的架构,以及事件驱动架构要达成的目标,和它在理论的零碎架构中所展示的状态。 事件驱动架构基本概念及状态在理解了对于事件驱动架构的一些根本形容之后,咱们须要进一步明确事件驱动架构所波及的一些基本概念和架构状态。依据维基百科形容,事件驱动架构波及的外围概念如下所示: 事件驱动架构根本状态围绕事件的流转,依据事件驱动架构的概念和根本状态,次要波及以下四个外围局部: Event Producer:负责产生事件,并将产生的事件投递到事件通道;Event Channel:负责接管事件,并将接管的事件长久化存储,投递给订阅该事件的后端解决引擎;Event Processing Engine:负责对于订阅的事件做出响应和解决,依据事件更新零碎状态;Downstream event-driven activity:事件处理实现之后,对于事件处理响应的一种展现;事件驱动架构要达成的目标理解了事件驱动架构的根本状态,架构中事件通道的引入,解耦了事件生产和事件处理这两个最根本的零碎角色,那么这样的架构模型所要达成的最终目标到底是什么? 零碎架构松耦合事件生产者与事件订阅者在逻辑上是离开的。事件的生成与应用的拆散意味着服务具备互操作性,但能够独立扩缩、更新和部署。 只面向事件的涣散耦合能够缩小零碎依赖项,并容许您以不同的语言和框架实现服务。您无需更改任何一个服务的逻辑,即可增加或移除事件生成方和接管方。您无需编写自定义代码来轮询、过滤和路由事件。 零碎的可伸缩性基于事件驱动架构的松耦合个性,意味着能够独立对事件生产者,事件通道服务,以及事件处理引擎进行独立的扩缩容;尤其对于后端事件处理引擎,能够依据音讯解决响应 SLA 和后端资源供应进行弹性扩缩容;同时能够基于事件粒度构建不同规格的后端解决服务,实现更细粒度的零碎弹性伸缩。 零碎的可扩展性零碎的可扩展性,次要体现在当零碎须要减少新的性能,如何疾速的基于现有零碎架构疾速构建反对新的业务逻辑,在事件驱动架构利用中,围绕事件粒度的解决模式,可能人造疾速反对减少新的基于事件的数据流形象。 当零碎中减少新的事件类型的时候,无需调整变更公布整个零碎,只须要关注须要订阅的事件进行事件处理逻辑的开发和部署即可,也能够基于原来的零碎做很少的代码变更即可实现,也能够在业务初期通过独立的服务订阅指定的事件实现特定的业务逻辑反对。 **为什么函数计算是云上事件驱动服务最佳实际? **在探讨完事件驱动架构根本模型之后,我想对于事件驱动的概念,状态咱们有了对立的意识和了解,接下来咱们进入议题的第二个局部,为什么函数计算是云上事件驱动服务最佳实际? 函数计算简介函数计算 FC 是一款基于事件驱动的全托管计算服务,相干的产品细节能够见官网介绍。作为一款通用的事件驱动型计算服务,接下来我会从三个方面进行具体的介绍。 编程范式应用函数计算,用户无需洽购与治理服务器等基础设施,只需编写并上传代码。函数计算为你筹备好计算资源,弹性地、牢靠地运行工作,并提供日志查问、性能监控和报警等开箱即用性能,编程范式带来开发的“简略,快捷”。 依照函数粒度进行独立的性能单元开发,疾速调试,疾速的部署上线,省去了大量资源购买,环境搭建的运维工作;同时函数计算是一个事件驱动的模型,事件驱动,意味着用户不须要关注服务产品数据传递的问题,省去了在编写代码中波及的大量服务拜访连贯的逻辑;“事件驱动” + “函数粒度开发” + “免服务器运维”等几个维度特色帮忙函数计算撑持“聚焦业务逻辑麻利开发”的底层逻辑。 计算模型除了开发模式带来的研发效力晋升之外,函数计算提供十分细粒度的计算资源和毫秒级计费模型,撑持按需计算,按量免费;可能反对按用户的申请,依据用户流量的模型为计算付费;当然按用户申请付费存在技术上微小的挑战,要求函数计算实例的启动小于用户的 RT 要求,冷启动性能尤为重要,这时候极致弹性成为了 Serverless 按需付费,业务降本的底层技术撑持。函数计算通过“极致弹性” + “按需付费”的模型帮忙 Serverless 函数计算实现真正的按需计算逻辑。 ...