LMAX Disruptor——一个高性能、低延迟且简单的框架

 翻译:杨帆 校对:丁一

Disruptor是一个用于在线程间通信的高效低延时的消息组件,它像个增强的队列,并且它是让LMAX Exchange跑的如此之快的一个关键创新。关于什么是Disruptor、为何它很重要以及它的工作原理方面的信息都呈爆炸性增长 —— 这些文章很适合开始学习Disruptor,还可跟着LMAX BLOG深入学习。这里还有一份更详细的白皮书

虽然disruptor模式使用起来很简单,但是建立多个消费者以及它们之间的依赖关系需要的样板代码太多了。为了能快速又简单适用于99%的场景,我为Disruptor模式准备了一个简单的领域特定语言。例如,为建立一个消费者的四边形模式

(从Trisha Gee’s excellent series explaining thedisruptor pattern偷来的图片)

在这种情况下,只要生产者(P1)将元素放到ring buffer上,消费者C1C2就可以并行处理这些元素。但是消费者C3必须一直等到C1C2处理完之后,才可以处理。在现实世界中的对应的案例就像:在处理实际的业务逻辑(C3)之前,需要校验数据(C1),以及将数据写入磁盘(C2)。

用原生的Disruptor语法来创建这些消费者的话代码如下:

01

Executor executor = Executors.newCachedThreadPool();

02

BatchHandler handler1 = new MyBatchHandler1();

03

BatchHandler handler2 = new MyBatchHandler2();

04

BatchHandler handler3 = new MyBatchHandler3()

05

RingBuffer ringBuffer = new RingBuffer(ENTRY_FACTORY, RING_BUFFER_SIZE);

06

ConsumerBarrier consumerBarrier1 = ringBuffer.createConsumerBarrier();

07

BatchConsumer consumer1 = new BatchConsumer(consumerBarrier1, handler1);

08

BatchConsumer consumer2 = new BatchConsumer(consumerBarrier1, handler2);

09

ConsumerBarrier consumerBarrier2 =

10

ringBuffer.createConsumerBarrier(consumer1, consumer2);

11

BatchConsumer consumer3 = new BatchConsumer(consumerBarrier2, handler3);

12

executor.execute(consumer1);

13

executor.execute(consumer2);

14

executor.execute(consumer3);

15

ProducerBarrier producerBarrier =

16

ringBuffer.createProducerBarrier(consumer3);

在以上这段代码中,我们不得不创建那些个handler(就是那些个MyBatchHandler实例),外加消费者屏障,BatchConsumer实例,然后在他们各自的线程中处理这些消费者。DSL能帮我们完成很多创建工作,最终的结果如下:

1

Executor executor = Executors.newCachedThreadPool();

2

BatchHandler handler1 = new MyBatchHandler1();

3

BatchHandler handler2 = new MyBatchHandler2();

4

BatchHandler handler3 = new MyBatchHandler3();

5

DisruptorWizard dw = new DisruptorWizard(ENTRY_FACTORY,

6

    RING_BUFFER_SIZE, executor);

7

dw.consumeWith(handler1, handler2).then(handler3);

8

ProducerBarrier producerBarrier = dw.createProducerBarrier();

我们甚至可以在一个更复杂的六边形模式中构建一个并行消费者链:

1

dw.consumeWith(handler1a, handler2a);

2

dw.after(handler1a).consumeWith(handler1b);

3

dw.after(handler2a).consumeWith(handler2b);

4

dw.after(handler1b, handler2b).consumeWith(handler3);

5

ProducerBarrier producerBarrier = dw.createProducerBarrier();

这个领域特定语言刚刚诞生不久,欢迎任何反馈,也欢迎大家githubfork并改进它。

转载自并发编程网 – ifeve.com本文链接地址: LMAX Disruptor——一个高性能、低延迟且简单的框架

并发框架Disruptor译文

如何使用Disruptor(一)Ringbuffer的特别之处

如何使用Disruptor(二)如何从Ringbuffer读取

如何使用Disruptor(三)写入 Ringbuffer

解析Disruptor的依赖关系

Disruptor(无锁并发框架)-发布

LMAX Disruptor——一个高性能、低延迟且简单的框架

Disruptor Wizard已死,Disruptor Wizard永存!

Disruptor 2.0更新摘要

线程间共享数据无需竞争


  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值