当前位置: 首页 > java >正文

基于DolphinScheduler抽取通用EventBus组件:支持延迟与事件驱动

一、思路来源

虽然guava中的eventbus已经很方便了,但是还是想要实现一个更为方便,同时支持延迟事件、同时带eventbus的组件。在Apache DolphinScheduler项目中,有一个eventbus的组件,这个组件写得挺好的,想着用在业务系统上,因此自己抽取了一下,拿到业务系统中来用。话不多说,我们把它抽取出来吧,同时进行demo的运行。还是要感谢Apache DolphinScheduler的开源,让这个很简单,但是很高效的组件能够让我们便捷地使用。

二、具体实现过程

首先是定义事件接口:

public interface IEvent {
}

针对事件接口,我们抽象出共性方法接口:延迟时间和过期时间。

public abstractclass AbstractDelayEvent implements IEvent, Delayed {privatefinallong delayTime;privatefinallong expireTime;public long getDelayTime() {return delayTime;}public long getExpireTime() {return expireTime;}public AbstractDelayEvent(long delayTime) {this.delayTime = delayTime;this.expireTime = System.currentTimeMillis() + delayTime;}@Overridepublic long getDelay(TimeUnit unit) {long diff = expireTime - System.currentTimeMillis();return unit.convert(diff, TimeUnit.MILLISECONDS);}@Overridepublic int compareTo(Delayed o) {if (this.expireTime < ((AbstractDelayEvent) o).expireTime) {return -1;}if (this.expireTime > ((AbstractDelayEvent) o).expireTime) {return1;}return0;}
}

主要的信息:

定义eventbus中,我们需要使用的方法:

public interface IEventBus<T extends IEvent> {void publish(T event);Optional<T> poll() throws InterruptedException;Optional<T> peek();Optional<T> remove();boolean isEmpty();int size();
}

可以看到主要是:发布事件、消费、移除、删除、判断当前的事件是否为空,以及事件大小等方法。其中最重要的方法为发布事件和消费处理事件方法。

针对当前的事件bus接口进行抽象,抽取出共性方法,方便复用:

public abstractclass AbstractDelayEventBus<T extends AbstractDelayEvent> implements IEventBus<T> {protectedfinal DelayQueue<T> delayEventQueue = new DelayQueue<>();@Overridepublic void publish(T event) {delayEventQueue.put(event);}@Overridepublic Optional<T> poll() throws InterruptedException {// 使用带超时的 poll 方法,等待事件到期return Optional.ofNullable(delayEventQueue.poll(1000, TimeUnit.MILLISECONDS));}@Overridepublic Optional<T> peek() {return Optional.ofNullable(delayEventQueue.peek());}@Overridepublic Optional<T> remove() {return Optional.ofNullable(delayEventQueue.poll());}@Overridepublic boolean isEmpty() {return delayEventQueue.isEmpty();}@Overridepublic int size() {return delayEventQueue.size();}
}

三、测试运行效果

接下来,我们使用它,来进行处理:

定义自己的延迟事件:

如果是在业务中,可以定义自己的业务数据信息事件对象

public class MyDelayEvent extends AbstractDelayEvent {private final String message;public MyDelayEvent(long delayTime, String message) {super(delayTime);this.message = message;}public String getMessage() {return message;}
}

定义事件延迟事件bus

当然也可以进行自己的可定制化特性。

public class MyDelayEventBus extends AbstractDelayEventBus<MyDelayEvent> {// 不需要额外的修改
}

进行测试:

思路:创建事件总线、发布事件,然后针对发布的事件信息,进行消费,然后等待延迟时间的到来,从而实现消费,从而进行业务的处理。

import java.util.Optional;publicclass EventBusExample {public static void main(String[] args) throws InterruptedException {// 创建事件总线IEventBus<MyDelayEvent> eventBus = new MyDelayEventBus();// 发布单个事件eventBus.publish(new MyDelayEvent(100, "Single Event"));System.out.println("After publish, event bus size: " + eventBus.size());// 持续尝试消费事件while (true) {Optional<MyDelayEvent> event = eventBus.poll();if (event.isPresent()) {System.out.println("Received event: " + event.get().getMessage());} else {System.out.println("No event received within the timeout.");break;}}// 检查总线大小System.out.println("Event bus size: " + eventBus.size());}
}

运行结果:

抽取

可以看到实现自己的业务逻辑还是很方便的,可以自己实现吧,这里给出的代码是可以运行的。

  • 源码地址:https://gitee.com/null_713_2407/pratice
  • 参考:
    github:https://github.com/apache/dolphinscheduler

作者 | 刘亚洲

http://www.xdnf.cn/news/7321.html

相关文章:

  • centos把jar包配置成服务并设置开机自启
  • 基于ac自动机的内容审核
  • PyTorch模型保存方式
  • C++ —— Lambda 表达式
  • 虚拟地址空间
  • 第四章、SKRL(1): Examples
  • Python实例题:Python 实现简易 Shell
  • Python的传参过程的小细节
  • 什么是5G前传、中传、回传?
  • 数据分析—Excel数据清洗函数
  • Compose Kotlin Multiplatform跨平台基础运行
  • CM0启动CM7_0、CM7_1注意事项
  • PCB设计教程【入门篇】——电路分析基础-基本元件(电阻电容电感)
  • Docker 入门指南:从安装配置到核心概念解析
  • [ 计算机网络 ] | 宏观谈谈计算机网络
  • 十三、Hive 行列转换
  • 计算机视觉与深度学习 | Python实现ARIMA-WOA-CNN-LSTM时间序列预测(完整源码和数据
  • netcore项目使用winforms与blazor结合来开发如何按F12,可以调出chrome devtool工具辅助开发
  • 通过低功耗蓝牙通信实例讲透 MCU 各个定时器
  • AT 指令详解:基于 MCU 的通信控制实战指南AT 指令详解
  • ESP32开发-两个WIFI设备的通讯搭建
  • AI大模型从0到1记录学习numpy pandas day25
  • 无人设备遥控器之数据压缩与编码技术篇
  • PLC组网的方法、要点及实施全解析
  • android13以太网静态ip不断断开连上问题
  • C++(24):容器类<list>
  • Unreal 从入门到精通之SceneCaptureComponent2D实现UI层3D物体360°预览
  • MAC常用操作整理
  • MAC电脑中右键后复制和拷贝的区别
  • C++:与7无关的数