Package org.jgroups.tests

Source Code of org.jgroups.tests.AckReceiverWindowStressTest$Adder

package org.jgroups.tests;

import org.jgroups.stack.AckReceiverWindow;
import org.jgroups.Message;
import org.jgroups.Global;
import org.jgroups.util.Util;
import org.jgroups.util.Tuple;
import org.testng.annotations.Test;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicLong;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.List;


/**
* Tests time for N threads to insert and remove M messages into an AckReceiverWindow
* @author Bela Ban
*/
@Test(groups=Global.FUNCTIONAL, sequential=true)
public class AckReceiverWindowStressTest {
    static final int NUM_MSGS=1000000;
    static final int NUM_THREADS=50;
    static final int SEGMENT_SIZE=50000;

    @Test
    public static void stressTest() {
        start(NUM_THREADS, NUM_MSGS, SEGMENT_SIZE);
    }


    private static void start(int num_threads, int num_msgs, int segment_size) {
        final AckReceiverWindow win=new AckReceiverWindow(1, segment_size);
        final AtomicInteger counter=new AtomicInteger(num_msgs);
        final AtomicLong seqno=new AtomicLong(1);
        final AtomicInteger removed_msgs=new AtomicInteger(0);

        final CountDownLatch latch=new CountDownLatch(1);
        Adder[] adders=new Adder[num_threads];
        for(int i=0; i < adders.length; i++) {
            adders[i]=new Adder(win, latch, counter, seqno, removed_msgs);
            adders[i].start();
        }

        long start=System.currentTimeMillis();
        latch.countDown(); // starts all adders

        for(Adder adder: adders) {
            try {
                adder.join();
            }
            catch(InterruptedException e) {
                e.printStackTrace();
            }
        }

        for(int i=0; i < 50; i++) {
            if(removed_msgs.get() >= num_msgs)
                break;
            else {
                System.out.println("removed: " + removed_msgs.get());
                Util.sleep(100);
                List<Message> msgs=win.removeManyAsList(segment_size);
                if(msgs != null && !msgs.isEmpty())
                    removed_msgs.addAndGet(msgs.size());
            }
        }

        long time=System.currentTimeMillis() - start;
        double requests_sec=num_msgs / (time / 1000.0);
        System.out.println("\nTime: " + time + " ms, " + Util.format(requests_sec) + " requests / sec\n");
        System.out.println("Total removed messages: " + removed_msgs);
        assert removed_msgs.get() == num_msgs :
                "removed messages (" + removed_msgs.get() + ") != num_msgs (" + num_msgs + ")";
    }


    static class Adder extends Thread {
        final AckReceiverWindow win;
        final CountDownLatch latch;
        final AtomicInteger num_msgs;
        final AtomicLong current_seqno;
        final AtomicInteger removed_msgs;
        final static AtomicBoolean processing=new AtomicBoolean(false);

        public Adder(AckReceiverWindow win, CountDownLatch latch, AtomicInteger num_msgs,
                     AtomicLong current_seqno, AtomicInteger removed_msgs) {
            this.win=win;
            this.latch=latch;
            this.num_msgs=num_msgs;
            this.current_seqno=current_seqno;
            this.removed_msgs=removed_msgs;
        }


        public void run() {
            try {
                latch.await();
            }
            catch(InterruptedException e) {
                e.printStackTrace();
                return;
            }

            Message msg=new Message(false);

            while(num_msgs.getAndDecrement() > 0) {
                long seqno=current_seqno.getAndIncrement();

                int result=win.add2(seqno, msg);
                if(result != 1)
                    System.err.println("seqno " + seqno + " not added correctly");

                // simulates UNICAST: all threads call add2() concurrently, but only 1 thread removes messages
                if(processing.compareAndSet(false, true)) {
                    try {
                        while(true) {
                            List<Message> msgs=win.removeManyAsList(20000);
                            if(msgs == null || msgs.isEmpty())
                                break;
                            removed_msgs.addAndGet(msgs.size());
                        }
                    }
                    finally {
                        processing.set(false);
                    }
                }
            }
        }
    }


    @Test(enabled=false)
    public static void main(String[] args) {
        int num_threads=50;
        int num_msgs=1000000;
        int segment_size=20000;

        for(int i=0; i < args.length; i++) {
            if(args[i].equals("-num_threads")) {
                num_threads=Integer.parseInt(args[++i]);
                continue;
            }
            if(args[i].equals("-num_msgs")) {
                num_msgs=Integer.parseInt(args[++i]);
                continue;
            }
            if(args[i].equals("-segment_size")) {
                segment_size=Integer.parseInt(args[++i]);
                continue;
            }
            System.out.println("AckReceiverWindowStressTest [-num_msgs msgs] [-num_threads threads] [-segment_size <size>]");
            return;
        }
        start(num_threads, num_msgs, segment_size);
    }
}
TOP

Related Classes of org.jgroups.tests.AckReceiverWindowStressTest$Adder

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.