Disruptor之粗糙认识
一 概述
1.Disruptor
Disruptor是一个高性能的异步处理框架,一个“生产者-消费者”模型。
2.RingBuffer
RingBuffer是一种环形数据结构,包含一个指向下一个槽点的序号,可以在线程间传递数据。
3.Event
在Disruptor框架中,生产者生产的数据叫做Event。
二 Disruptor框架基本构成
1.MyEvent:自定义对象,充当“生产者-消费者”模型中的数据。
2.MyEventFactory:实现EventFactory的接口,用于生产数据。
3.MyEventProducerWithTranslator:将数据存储到自定义对象中并发布。
4.MyEventHandler:自定义消费者。
三 Demo
初次接触Disruptor,认识停留在表面,零散,模糊,在此记一个简单的示例,以便日后深入研究。
1.自定义数据类
- package com.disruptor.basic;
- public class LongEvent {
- private long value;
- public long getValue() {
- return value;
- }
- public void setValue(long value) {
- this.value = value;
- }
- }
2.数据生产工厂(创建数据类对象)
- package com.disruptor.basic;
- import com.lmax.disruptor.EventFactory;
- public class LongEventFactory implements EventFactory<LongEvent> {
- public LongEvent newInstance() {
- // TODO Auto-generated method stub
- return new LongEvent();
- }
- }
3.数据源(初始化数据对象并发布)
- package com.disruptor.basic;
- import java.nio.ByteBuffer;
- import com.lmax.disruptor.EventTranslatorOneArg;
- import com.lmax.disruptor.RingBuffer;
- public class LongEventProducerWithTranslator {
- private final RingBuffer<LongEvent> ringBuffer;
- public LongEventProducerWithTranslator(RingBuffer<LongEvent> ringBuffer) {
- this.ringBuffer = ringBuffer;
- }
- private final EventTranslatorOneArg<LongEvent, ByteBuffer> TRANSLATOR = new EventTranslatorOneArg<LongEvent, ByteBuffer>() {
- /**
- * event:包含有消费数据的对象; sequence:分配给目标对象的RingBuffer空间序号;
- * bb:包含有将要被存储到目标对象中的数据的容器
- */
- public void translateTo(LongEvent event, long sequence, ByteBuffer bb) {
- // TODO Auto-generated method stub
- event.setValue(bb.getLong(0));// 将数据存储到目标对象中
- }
- };
- public void onData(ByteBuffer bb) {
- ringBuffer.publishEvent(TRANSLATOR, bb);// 发布,将数据推送给消费者
- }
- }
4.消费者
- package com.disruptor.basic;
- import com.lmax.disruptor.EventHandler;
- public class LongEventHandler implements EventHandler<LongEvent> {
- public void onEvent(LongEvent event, long sequence, boolean endOfBatch) throws Exception {
- // TODO Auto-generated method stub
- System.out.println("当前消费的数据="+event.getValue());
- }
- }
5.测试类
- package com.disruptor.basic;
- import java.nio.ByteBuffer;
- import java.util.concurrent.ExecutorService;
- import java.util.concurrent.Executors;
- import org.junit.Test;
- import com.lmax.disruptor.EventFactory;
- import com.lmax.disruptor.RingBuffer;
- import com.lmax.disruptor.YieldingWaitStrategy;
- import com.lmax.disruptor.dsl.Disruptor;
- import com.lmax.disruptor.dsl.ProducerType;
- public class LongEventTest {
- @SuppressWarnings({ "unchecked", "deprecation" })
- @Test
- public void test01() throws InterruptedException {
- ExecutorService executor = Executors.newCachedThreadPool();
- EventFactory<LongEvent> factory = new LongEventFactory();
- int bufferSize = 1024;
- Disruptor<LongEvent> disruptor = new Disruptor<LongEvent>(factory, bufferSize, executor, ProducerType.SINGLE,
- new YieldingWaitStrategy());
- disruptor.handleEventsWith(new LongEventHandler());
- disruptor.start();
- RingBuffer<LongEvent> ringBuffer = disruptor.getRingBuffer();
- // LongEventProducer producer = new
- // LongEventProducer(ringBuffer);
- LongEventProducerWithTranslator producer = new LongEventProducerWithTranslator(ringBuffer);
- ByteBuffer bb = ByteBuffer.allocate(8);
- // long startTime = System.currentTimeMillis();
- for (long a = 0; a < 100; a++) {
- bb.putLong(0, a);
- producer.onData(bb);
- /*if (a == 99) {
- long endTime = System.currentTimeMillis();
- System.out.println("useTime=" + (endTime - startTime));
- }*/
- Thread.sleep(100);
- }
- /*long endTime = System.currentTimeMillis();
- System.out.println("useTime=" + (endTime - startTime));*/
- disruptor.shutdown();
- executor.shutdown();
- }
- /*@Test
- public void test02() {
- long startTime = System.currentTimeMillis();
- for (long a = 0; a < 100; a++) {
- System.out.println(a);
- }
- long endTime = System.currentTimeMillis();
- System.out.println("useTime=" + (endTime - startTime));
- }*/
- }
Disruptor之粗糙认识的更多相关文章
- 架构师养成记--15.Disruptor并发框架
一.概述 disruptor对于处理并发任务很擅长,曾有人测过,一个线程里1s内可以处理六百万个订单,性能相当感人. 这个框架的结构大概是:数据生产端 --> 缓存 --> 消费端 缓存中 ...
- 并发框架Disruptor浅析
1.引言 Disruptor是一个开源的Java框架,它被设计用于在生产者—消费者(producer-consumer problem,简称PCP)问题上获得尽量高的吞吐量(TPS)和尽量低的延迟.D ...
- LMAX Disruptor—多生产者多消费者中,消息复制分发的高性能实现
解决的问题 当我们有多个消息的生产者线程,一个消费者线程时,他们之间如何进行高并发.线程安全的协调? 很简单,用一个队列. 当我们有多个消息的生产者线程,多个消费者线程,并且每一条消息需要被所有的消费 ...
- Disruptor 极速体验
已经不记得最早接触到 Disruptor 是什么时候了,只记得发现它的时候它是以具有闪电般的速度被介绍的.于是在脑子里, Disruptor 和"闪电"一词关联了起来,然而却一直没 ...
- disruptor - Concurrent Programming Framework 并发编程框架
disruptor发布了Java的2.0版本(.Net版本见这里),disruptor是一个高性能的异步处理框架,或者可以认为是最快的消息框架(轻量的JMS),也可以认为是一个观察者模式实现,或者事件 ...
- 剖析Disruptor:为什么会这么快?(二)神奇的缓存行填充
原文链接:http://mechanitis.blogspot.com/2011/07/dissecting-disruptor-why-its-so-fast_22.html 需FQ 计算机入门 ...
- The LMAX disruptor Architecture--转载
原文地址: LMAX is a new retail financial trading platform. As a result it has to process many trades wit ...
- Disruptor 源码阅读笔记--转
原文地址:http://coderbee.net/index.php/open-source/20130812/400 一.Disruptor 是什么? Disruptor 是一个高性能异步处理框架, ...
- 构建高性能服务(三)Java高性能缓冲设计 vs Disruptor vs LinkedBlockingQueue--转载
原文地址:http://maoyidao.iteye.com/blog/1663193 一个仅仅部署在4台服务器上的服务,每秒向Database写入数据超过100万行数据,每分钟产生超过1G的数据.而 ...
随机推荐
- 在Windows上搭建Git Server (2)
第一步:下载Java,下载地址:http://www.java.com/zh_CN/ 第二步:安装Java.安装步骤不再详述. 第三步:配置Java环境变量. 右键”计算机” => ”属性” ...
- easyui datagrid可编辑表格使用经验分享
文章目录 1相关接口方法 2列属性formatter 3编辑器类型 3.1基于my97的编辑器 3.2简单的密码编辑器 3.3动态增加/删除编辑器 4字段的级联操作 4.1combobox的级联操作 ...
- 对KMP算法通过代码生成next数组理解
本文是根据考研数据结构2019版天勤高分笔记理解编写的: 首先给出代码: 1 void getnext(Str substr,int next[]){ 2 int i=0,j=0; 3 next[1] ...
- 老男孩python作业4-ATM程序开发
实现一个ATM + 购物商城程序: 额度 15000或自定义 实现购物商城,买东西加入 购物车,调用信用卡接口结账 可以提现,手续费5% 支持多账户登录 支持账户间转账 记录每月日常消费流水 提供还款 ...
- LeetCode8. 字符串转整数 (atoi)
8. 字符串转整数 (atoi) 描述 实现 atoi,将字符串转为整数. 在找到第一个非空字符之前,需要移除掉字符串中的空格字符.如果第一个非空字符是正号或负号,选取该符号,并将其与后面尽可能多的连 ...
- 基于 bootstrap html 响应式 布局
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8& ...
- C# 利用Powershell获取网络相关信息
利用Get-NetAdapter获取信息 Get-NetAdapter 参考链接:https://docs.microsoft.com/en-us/powershell/module/netadapt ...
- phantomjs的和谷歌浏览器的简单使用
一.phantomjs的简单使用 ''' 什么是phantomJs:无界面的浏览器 ''' from selenium import webdriver from time import sleep ...
- ssh无密码登录和scp无密码拷贝
目的:在A主机上无密码登录B主机 方法: A主机生成密钥:ssh-keygen -t rsa 将密钥复制到B主机:cat ~/.ssh/id_rsa.pub | ssh root@B 'cat > ...
- css引入 以及选择器040
css的介绍: css(Cascading Style Sheet) 层叠样式表 作用就是给HTML页面标签议案家各种样式 定义网页效果 简单来说 就是讲网页内容和显示样式进行分离 , 提高了显示功 ...