事件机制
优质
小牛编辑
167浏览
2023-12-01
为什么要事件机制?
答案是:为了解耦,保持自身的独立和简洁,从而降低系统复杂度。
举个例子: 用户注册功能几乎是互联网系统必备的功能,用户注册的功能非常简单,用户提交注册信息,系统验证用户合法性后保存信息到数据库。
但是,由于运营等需求,可能在某个时间点需要增加某个功能,例如:
- 在元旦的时候,注册用户添加2个积分。
- 新的需求用户注册成功后,需要发送一封邮件。
- 在情人节给注册邀请人10积分。
- 公司老板今天的生日、注册自动升级为xxx会员。
- ... 等等等等
同时,在稍微复杂的系统里,一个系统往往可能会有多个注册入口,比如网页注册、APP通过api注册、微信用户自动登录时注册、第三方用户登录时进行注册...
那么,此时,注册功能每添加一个新的需求,就需要修改很多地方的代码...出现很多的代码冗余。
如何解决呢?
此时就用到了事件机制了。在用户注册的时候,系统只需要发送一个新用户注册的事件,让事件的监听器去获取这个事件后,执行自己的业务逻辑。
每个需求,就是一个事件监听器。当有新的需求出现的时候,我们只需要写一个新的事件监听器就可以了,其他任何地方的所有代码都不需要改动。
Jboot 事件机制的使用
事件机制由两部分组成,一个是发送者,一个是接收者。发送者只是一个抽象的概念,在 Jboot 中并没有这个对象的存在。
当我们需要发送事件的时候,只需要调用如下代码就可以了。
Jboot.sendEvent("eventName", data)
事件监听器如何监听到这个事件呢,只需要2步:
- 编写一个类(任意名称)实现
JbootEventListener
接口 - 通过
@EventConfig
注解配置上这个编写的类
例如:
@EventConfig(action = {"eventName","event1","event2"})
public class MyEventListener implements JbootEventListener {
public void onEvent(JbootEvent event){
Object data = event.getData();
System.out.println("get data:"+data);
}
}
此时,当有 eventName
, event1
, event2
任何一个事件发送的时候,以上的 MyEventListener.onEvent
都会被触发执行。
备注
事件机制和 MQ(消息队列)很相似,主要区别是在于事件机制只是在 Jvm 应用内执行,解决的业务之间的耦合问题。
MQ(消息队列)解决的是分布式下,多个系统的事件(或者消息)发送和监听,MQ 需要第三方的 中间件 ,例如:Redis、rabbitMQ、activeMQ...等。