Disruptor與BlockingQueue壓力測(cè)試性能對(duì)比

歡迎關(guān)注作者簡(jiǎn)書
csdn傳送門

1、先熟悉下什么是阻塞隊(duì)列!

傳送門

2权薯、代碼壓測(cè)

2.1、公共部分
package com.bfxy.disruptor.ability;

public interface Constants {

    int EVENT_NUM_OHM = 100000000;
    
    int EVENT_NUM_FM = 50000000;
    
    int EVENT_NUM_OM = 10000000;
    
}

package com.bfxy.disruptor.ability;

import java.io.Serializable;

public class Data implements Serializable {

    private static final long serialVersionUID = 2035546038986494352L;
    private Long id ;
    private String name;
    
    public Data() {
    }
    public Data(Long id, String name) {
        super();
        this.id = id;
        this.name = name;
    }
    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}
2.2睡扬、ArrayBlockingQueue壓測(cè)
package com.bfxy.disruptor.ablility;

import com.bfxy.disruptor.ability.Data;

import java.util.concurrent.ArrayBlockingQueue;

public class ArrayBlockingQueue4Test {

    public static void main(String[] args) {
        final ArrayBlockingQueue<Data> queue = new ArrayBlockingQueue<>(100000000);
        final long startTime = System.currentTimeMillis();
        // 向容器中添加元素
        new Thread(new Runnable() {
            @Override
            public void run() {
                long i = 0;
                while(i < Constants.EVENT_NUM_FM) {
                    try {
                        queue.put(new Data(i, "c"+i));
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    i++;
                }
            }
        }).start();
        // 從容器中取出元素
        new Thread(new Runnable() {
            @Override
            public void run() {
                long k = 0;
                while (k < Constants.EVENT_NUM_FM) {
                    try {
                        queue.take();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    k++;
                }
                long endTime = System.currentTimeMillis();
                System.out.println("ArrayBlockingQueue costTime = " + (endTime - startTime) + "ms");
            }
        }).start();
    }
}
2.3盟蚣、DisruptorSingle壓測(cè)
package com.bfxy.disruptor.ability;

import com.lmax.disruptor.EventHandler;

public class DataConsumer implements EventHandler<Data> {

    private long startTime;
    private int i;

    public DataConsumer() {
        this.startTime = System.currentTimeMillis();
    }

    @Override
    public void onEvent(Data data, long seq, boolean bool)
            throws Exception {
        i++;
        if (i == Constants.EVENT_NUM_OHM) {
            long endTime = System.currentTimeMillis();
            System.out.println("Disruptor costTime = " + (endTime - startTime) + "ms");
        }
    }

}
package com.bfxy.disruptor.ability;

import java.util.concurrent.Executors;

import com.lmax.disruptor.BlockingWaitStrategy;
import com.lmax.disruptor.BusySpinWaitStrategy;
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 DisruptorSingle4Test {

    public static void main(String[] args) {
        int ringBufferSize = 65536;
        final Disruptor<Data> disruptor = new Disruptor<Data>(
                 new EventFactory<Data>() {
                     @Override
                    public Data newInstance() {
                        return new Data();
                    }
                },
                ringBufferSize,
                Executors.newSingleThreadExecutor(),
                ProducerType.SINGLE, 
                //new BlockingWaitStrategy()
                new YieldingWaitStrategy()
                );

        DataConsumer consumer = new DataConsumer();
        //消費(fèi)數(shù)據(jù)
        disruptor.handleEventsWith(consumer);
        disruptor.start();
        new Thread(new Runnable() {
            @Override
            public void run() {
                RingBuffer<Data> ringBuffer = disruptor.getRingBuffer();
                for (long i = 0; i < Constants.EVENT_NUM_OHM; i++) {
                    long seq = ringBuffer.next();
                    Data data = ringBuffer.get(seq);
                    data.setId(i);
                    data.setName("c" + i);
                    ringBuffer.publish(seq);
                }
            }
        }).start();
    }
}

性能比較

NUM Disruptor BlockingQueue 性能占比
1千萬 984ms 2218ms 2.254
5千萬 4498ms 10589ms 2.354
1億 8229ms 21146ms 2.569

歡迎加入Java猿社區(qū)!
免費(fèi)領(lǐng)取我歷年收集的所有學(xué)習(xí)資料哦卖怜!

歡迎加入Java猿社區(qū).png

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末屎开,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子马靠,更是在濱河造成了極大的恐慌奄抽,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,204評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件甩鳄,死亡現(xiàn)場(chǎng)離奇詭異逞度,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)妙啃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門档泽,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人揖赴,你說我怎么就攤上這事馆匿。” “怎么了燥滑?”我有些...
    開封第一講書人閱讀 164,548評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵渐北,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我铭拧,道長(zhǎng)赃蛛,這世上最難降的妖魔是什么恃锉? 我笑而不...
    開封第一講書人閱讀 58,657評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮呕臂,結(jié)果婚禮上淡喜,老公的妹妹穿的比我還像新娘。我一直安慰自己诵闭,他們只是感情好炼团,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著疏尿,像睡著了一般瘟芝。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上褥琐,一...
    開封第一講書人閱讀 51,554評(píng)論 1 305
  • 那天锌俱,我揣著相機(jī)與錄音,去河邊找鬼敌呈。 笑死贸宏,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的磕洪。 我是一名探鬼主播吭练,決...
    沈念sama閱讀 40,302評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼析显!你這毒婦竟也來了鲫咽?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,216評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤谷异,失蹤者是張志新(化名)和其女友劉穎分尸,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體歹嘹,經(jīng)...
    沈念sama閱讀 45,661評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡箩绍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了尺上。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片材蛛。...
    茶點(diǎn)故事閱讀 39,977評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖尖昏,靈堂內(nèi)的尸體忽然破棺而出仰税,到底是詐尸還是另有隱情,我是刑警寧澤抽诉,帶...
    沈念sama閱讀 35,697評(píng)論 5 347
  • 正文 年R本政府宣布,位于F島的核電站吐绵,受9級(jí)特大地震影響迹淌,放射性物質(zhì)發(fā)生泄漏河绽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評(píng)論 3 330
  • 文/蒙蒙 一唉窃、第九天 我趴在偏房一處隱蔽的房頂上張望耙饰。 院中可真熱鬧,春花似錦纹份、人聲如沸苟跪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽件已。三九已至,卻和暖如春元暴,著一層夾襖步出監(jiān)牢的瞬間篷扩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工茉盏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鉴未,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,138評(píng)論 3 370
  • 正文 我出身青樓鸠姨,卻偏偏與公主長(zhǎng)得像铜秆,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子讶迁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • @(多線程&&并發(fā)) 微信消息處理隊(duì)列實(shí)現(xiàn) 歡迎關(guān)注作者簡(jiǎn)書csdn傳送門 @[toc]??首先先來介紹一下阻塞隊(duì)...
    阿祥小王子閱讀 1,679評(píng)論 0 0
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,101評(píng)論 1 32
  • 《不急不吼 輕松養(yǎng)出好孩子》這是蟲導(dǎo)參與書寫的一本新書羽峰。剛好有活動(dòng),自己就參與了添瓷。書梅屉,堅(jiān)持看了10天,每天都在一...
    海云書寫閱讀 381評(píng)論 0 0
  • 可能是因?yàn)楫?dāng)過兵鳞贷,我開始對(duì)戰(zhàn)爭(zhēng)片開始感興趣了坯汤,總想了解一下其他國(guó)家的士兵的生活狀況。 前段時(shí)間看過一部叫做《鍋蓋頭...
    5fc1bc4f8056閱讀 187評(píng)論 0 0