首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Lmax Disruptor,许多消费者-如何使消费者只接收特定类型的信息,并独立进行?

Lmax Disruptor,许多消费者-如何使消费者只接收特定类型的信息,并独立进行?
EN

Stack Overflow用户
提问于 2017-04-12 13:37:54
回答 2查看 734关注 0票数 3

我计划在我的干扰器中有许多类似的消费者。

我需要每个消费者只使用为他们准备的消息。

例如,我有A、B、C类型的消息,缓冲区类似

代码语言:javascript
运行
复制
 #1 - type A, #2 - type B, #3 - type C,  #4 - type A, #5 - type C, #6 - type C,  (and so on)

每种类型我都有消费者。我如何实现消费者的A将接受消息1和4,类型B-消息2,C-消息3,5,6?

重要事项:我希望处理过程是独立的。消费者不应该被链锁住,每个人都独立地运行缓冲器。“C”型消费者对#6的处理可能早于A型的1号,如果A型的消费者比C型慢的话。

我很感激如何使用LMAX中断配置来实现它。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-04-18 19:03:15

典型的模式是使用序列号--假设您有4个事件处理程序挂在一个中断程序上;如果给每个事件处理程序一个唯一的编号,您可以选择是否接受该消息:

代码语言:javascript
运行
复制
void onEvent(T event, long sequence, boolean endOfBatch) throws Exception {
    // instanceNumber could be assigned in a constructor 
   if ((sequence % 4) != instanceNumber) 
        // message isn't for me
        return;
   }
   // do my thing
}
票数 6
EN

Stack Overflow用户

发布于 2017-04-12 16:25:35

将干扰器配置为使用单一类型的对象,但创建多个中断器,每个对象类型一个。在上述情况下,将有三个单独的干扰者。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43371199

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档