高性能消息队列Disruptor

news/2025/2/3 2:55:48/

定义一个事件模型

之后创建一个java类来使用这个数据模型。

/*
<h1>事件模型工程类,用于生产事件消息</h1>
*/
no usages
public class EventMessageFactory implements EventFactory<EventMessage> {
@Overridepublic EventMessage newInstance(){
return new EventMessage();
}

之后需要定义一个异常处理类,如果发出的消息出现了异常使用这个异常处理类进行处理。

no usages
@Slf4j
public class EventMessageExceptionHandler implements ExceptionHandler<EventMessage> {
no usages
@Override
public void handleEventException(Throwable ex,long sequencer EventMessage event){
}
3 usages
@Override
public void handleOnStartException(Throwable ex){
}
4 usages
@Override
public void handle0nShutdownException(Throwable ex){}
}

第一个方法是处理事件时出现的异常。

第二个方法是处理消费线程之前出现的异常。

第三个方法是处理消费线程结束之前出现的异常。

之后定义一个消费者,也就是消息处理器。

在这个方法的外面定义一个header的名称

第一给方法是独立的消费者也就是处理每一个消费者的所有信息

第二个方法是公告消费者,不会处理重复的信息。

 之后定义一个工具类

第一个方法是初始化的方法

第二个方法是销毁之前需要执行的销毁方法

之后定义一个事件转换器

这个sequence可以看成是消息序号

之后定义一个disruptor,初始化放在第一个方法上面,然后定义一个ringBuffer,和一个消息工厂类。

然后定一个方法用于生产者发布消息

然后时消费者处理消息

之后对初始化方法进行修改。

 

这里面第一个参数是给消息分配空间

第二个参数是容器的大小

第三个是线程工厂的实现类

第四个是生产者的类型

最后一个参数是消息等待策略

然后对二个方法进行修改

 之后定义一个新的class类来实现EventMessageDisruptor,并在里面进行实现消费者。

在定义另一消费者类型的class。

然后来实现这两个消费者。


http://www.ppmy.cn/news/1568846.html

相关文章

全志 视频输入组件的使用

1.启动MPP和Glog库 示例代码&#xff1a; log_init(argv[0], &stGLogConfig);MPP_SYS_CONF_S stSysConf; memset(&stSysConf, 0, sizeof(MPP_SYS_CONF_S)); stSysConf.nAlignWidth 32; AW_MPI_SYS_SetConf(&stSysConf); ret AW_MPI_SYS_Init();2.获取配置文件信…

物联网 STM32【源代码形式-使用以太网】连接OneNet IOT从云产品开发到底层MQTT实现,APP控制 【保姆级零基础搭建】

物联网&#xff08;IoT&#xff09;‌是指通过各种信息传感器、射频识别技术、全球定位系统、红外感应器等装置与技术&#xff0c;实时采集并连接任何需要监控、连接、互动的物体或过程&#xff0c;实现对物品和过程的智能化感知、识别和管理。物联网的核心功能包括数据采集与监…

Git Rebase的使用

Git rebase是Git版本控制系统中的一个重要工具&#xff0c;用于重写提交历史&#xff0c;整合分支。通过rebase&#xff0c;可以使项目历史更加简洁和清晰。本文将深入探讨Git rebase的概念、用途、具体操作及其与其他Git命令的区别。 一、Git Rebase的概念 Git rebase是将一…

基于FPGA的BT656编解码

概述 BT656全称为“ITU-R BT.656-4”或简称“BT656”,是一种用于数字视频传输的接口标准。它规定了数字视频信号的编码方式、传输格式以及接口电气特性。在物理层面上,BT656接口通常包含10根线(在某些应用中可能略有不同,但标准配置为10根)。这些线分别用于传输视频数据、…

包装类(全面解析)

Java中的常用类 含义:直接调用实现一些功能【如:Arrays工具类中的方法】 主要关注常用类中的【以jdk api中的包装类为例】 A、字段摘要(一般只看全局常量,字段名是全大写即常量) B、构造方法摘要(通过看构造方法就能知道此类怎么去创建对象) C、方法摘要(一个方法…

文件系统分析

文件系统与磁盘管理详解 一、存储设备基础 1. 存储设备类型对比 设备类型特点典型接口应用场景机械硬盘依赖磁头机械读写&#xff0c;转速影响性能&#xff08;5400/7200/10000rpm&#xff09;&#xff0c;价格低容量大SATA/SAS冷数据存储、备份固态硬盘无机械结构&#xff…

解决使用Selenium时ChromeDriver版本不匹配问题

在学习Python爬虫过程中如果使用Selenium的时候遇到报错如下session not created: This version of ChromeDriver only supports Chrome version 99… 这说明当前你的chrome驱动版本和浏览器版本不匹配。 例如 SessionNotCreatedException: Message: session not created: This…

基于RFID的门禁系统的设计(论文+源码)

1系统方案设计 通过需求分析&#xff0c;基于RFID的门禁系统总体设计框图。系统采用STM32单片机作为系统主控核心&#xff0c;利用独立按键与RFID识别模块能够实现门禁系统密码与IC卡开门功能。WiFi模块实现系统与手机APP的通信&#xff0c;用户可以通过手机APP进行门禁开关操作…