《disruptor笔记》系列链接
关于独立消费和共同消费
-
本篇是《disruptor笔记》的第四篇,前面章节写了不少代码,搞得读者和作者都辛苦,本篇稍微放松一下,熟悉一个重要概念:disruptor事件的消费模式,包括独立消费和共同消费两种;
-
举个例子,假设在电商场景中,每产生一个订单都要发邮件和短信通知买家,如果产生了十个订单,就有以下两种情况要考虑:
第一种:要发十封邮件和十条短信,此时,邮件系统和短信系统是各自独立的,他们各自消费这十个订单的事件,也就是说十个事件被消费二十次,所以邮件系统和短信系统各自独立消费,彼此没有关系,如下图,一个原点代表一个事件:
第二种:假设邮件系统处理能力差,为了提升处理能力,部署了两台邮件服务器,因此是这两台邮件服务器共同处理十个订单事件,合起来一共发送了十封邮件,如下图,一号邮件服务器和二号邮件服务器是共同消费,某个订单事件只会在一个邮件服务器被消费:
独立消费的核心知识点
-
使用的API是handleEventsWith
-
业务处理逻辑放入EventHandler的实现类中
-
内部实现用BatchEventProcessor类,一个消费者对应一个BatchEventProcessor实例,任务是获取事件再调用EventHandler的onEvent方法处理
-
一个消费者对应一个SequenceBarrier实例,用于等待可消费事件
-
一个消费者对应一个Sequence实例(BatchEventProcessor的成员变量),用于记录消费进度
-
每个BatchEventProcessor实例都会被放入集合(consumerRepository.consumerInfos)
-
Disruptor的start方法中,会将BatchEventProcessor放入线程池执行,也就是说每个消费者都在独立线程中执行
共同消费的核心知识点
-
使用的API是handleEventsWithWorkerPool
-
业务处理逻辑放入WorkHandler的实现类中
-
内部实现用WorkerPool和WorkProcessor类合作完成的,WorkerPool实例只有一个,每个消费者对应一个WorkProcessor实例
-
SequenceBarrier实例只有一个,用于等待可消费事件
-
每个消费者都有自己的Sequence实例,另外还有一个公共的Sequence实例(WorkerPool的成员变量),用于记录消费进度
-
WorkerPool实例会包裹成WorkerPoolInfo实例再放入集合(consumerRepository.consumerInfos)
-
Disruptor的start方法中,会调用WorkerPool.start方法,这里面会将每个WorkProcessor放入线程池执行,也就是说每个消费者都在独立线程中执行
精简的小结
- 上述核心知识点还是有点多,咱们用对比来精简一下,以下是精华中的精华,真不能再省了,请重点关注:
学习分享,共勉
这里是小编拿到的学习资源,其中包括“中高级Java开发面试高频考点题笔记300道.pdf”和“Java核心知识体系笔记.pdf”文件分享,内容丰富,囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点。同时还有Java进阶学习的知识笔记脑图(内含大量学习笔记)!
资料整理不易,读者朋友可以转发分享下!
Java核心知识体系笔记.pdf
中高级Java开发面试高频考点题笔记300道.pdf
架构进阶面试专题及架构学习笔记脑图
Java架构进阶学习视频分享
1714285164929)]
架构进阶面试专题及架构学习笔记脑图
[外链图片转存中…(img-kZxsfPW5-1714285164929)]
Java架构进阶学习视频分享