其他分享
首页 > 其他分享> > 领域事件和集成事件没那么高大上

领域事件和集成事件没那么高大上

作者:互联网

前言

随着系统架构的演变,有很多名词也随之涌现,如:微服务、灰度发布、资源隔离、容器、领域/集成事件等,听着的确高大上,让很多小伙伴有一种无法征服的感觉;其实很多东西可能之前就已经用过了,只是名字不这么叫而已,就算没应用上也别慌,现在很多轮子都很成熟,用起来很容易上手的。这里就来说说比较常见的领域事件和集成事件。

正文

1.概述

微服务和DDD盛行的时代,领域事件和集成事件经常被提及到;对于事件,小伙伴可以根据不同场景去理解,比如点击一个按钮时,这个就是一个事件(点击事件),又或者说当购买商品时付款成功,也可以理解为一个事件,就像咱们在生活中对每一件事的定义是一样的。

1.1 领域事件

领域事件(Domain Event)是在一个特定领域由一个动作触发的,是发生在过去的行为产生的事件(行为可以是人操作的,也可以是系统自动的)

其实在项目中,通常咱们会把领域事件用在一个应用程序进程内,比如说在用户管理时,当用户注册成功时,需要发送邮件或短信提醒; 其中用户管理可以简单理解为一个领域,用户注册成功就是事件,而发送提醒就是针对事件的处理方式。

这里可能对领域的比喻不是特别恰当,如果小伙伴想更多了解,可以看看DDD(领域驱动设计)相关资料。

对于我个人的理解,我认为领域事件的主要目的是为了让代码更加容易维护,让业务更加容易扩展,也就是对代码业务层面的优化。如下图:

对于原始这种方式,相信很多小伙伴也和我曾经一样写过这样的代码逻辑,不用想什么代码顺序,直接撸码就行了,但是这样扩展性不好,比如我想加一个微信发送怎么办,还得在原来基础上继续加,如果过两天不要短信发送了,还得去改原来代码。这样是不是违背了软件开发的开闭原则,尽量还是少改原有逻辑的代码,避免重复修改、重复测试。

对于优化后的这种方式,只需要在注册成功之后发布一个事件出来就行了,至于后面要发送什么样的消息不用管,只要捕获到事件消息,只需新增额外扩展的处理器类即可,就算是取消,只需不捕获对应的事件就行,无需改动原有用户注册代码的逻辑。这种方式的事件就可以理解为领域事件。

小伙伴回想一下,之前在优化代码的时候是不是也这样做过,只是当时不称它为领域事件。

1.2 集成事件

集成事件(IntegrationEvent)同样也是指在过去的行为产生的事件(行为可以是人操作的,也可以是系统自动的),一般用于跨多个微服务或外部系统。

比如现在的电商系统,订单模块和物流模块会拆分为不同微服务,通常在订单支付成功之后,物流模块需要知道订单相关的明细,这样才会根据订单进行物流跟踪。所以订单在付款成功之后,就会发布一个事件出去,物流系统订阅到事件之后就可以处理对应业务逻辑。

对于集成事件的主要目的我认为就是为了让服务模块之间或系统之间的对接耦合性变低,只要约定好事件类型,发事件模块和处理事件的模块就会有很少对接,便于扩展和维护。如图:

原始的这种方式,像我有点年长的小伙伴应该之前都用过,当然现在有很多传统企业项目也是这种方式。这种方式主要是通过接口的形式进行模块或系统之间的对接,这样对接成本稍微偏高,因为订单服务还需要开发调用物流服务接口的逻辑,还要各种联调,考虑接口超时、失败等各种情况;另外如果还有其他业务模块的系统需要对接怎么办,如果接口规范不一样,还得重复再开发一套调用逻辑,这样后面订单服务这个模块就变得很臃肿,而且模块间的耦合性比较高。

优化后的方式就相对来说比较好,对订单付款成功之后,只需将事件发布出去就行了,剩下的不用过多干涉,对应的业务模块订阅到消息之后进行相关业务处理即可;这种模式就算有其他业务模块加入也会很便捷,模块间的耦合性比较低。由于模块间的消息需要传输,所以就需要EventBus来做这个事了。这种方式看上去不错,但需要第三方的消息中间件做消息转发和存储,如RabbitMq、Kafka等;另外使用过程中,消息的持久化、消息丢失的情况都需要考虑,后续会单独出相关系列的文章说这块。

2.演示

对于技术落地,大神都把轮子造好了,咱们拿来就可以用啦。

2.1 领域事件
2.2 集成事件

相关源码地址:https://gitee.com/CodeZoe/dot-net-core-study-demo

总结

关于领域事件和集成事件的介绍和使用暂时先说这么多,只是简单介绍了我对领域事件和集成事件的理解及应用,更多细节还得小伙伴根据实际业务需求进配置和改进,但用法就是这么简单;对于消息丢失、持久化等相关问题,后续会跟随消息队列的文章分享出来。

关注“Code综艺圈”,和我一起学习吧。

标签:集成,小伙伴,高大,RabbitMQ,领域,事件,模块
来源: https://www.cnblogs.com/zoe-zyq/p/16163724.html