* @param args
*/
public static void main(String[] args) {
Dispatcher disp = Dispatcher.getInstance();
ThreadGroup group = ThreadUtil.topGroup();
StopWatch sw = new StopWatch(10);
disp.register(new InputStage(sw));
disp.register(new LightStage());
disp.register(new WeightStage());
disp.register(new FinishStage());
disp.construction();
disp.startAdjust(1000);
group.list();
sw.begin(false);
System.out.println("Stage 1 - dispatch 5K/s, 100(1ms) : 1(100ms) weight messages; for 30 sec.");
for (int i = 0; i < 30; ++i) {
for (int j = 0; j < 5000; ++j) {
if (j % 100 == 50) {
disp.dispatch("input", new WeightMessage(100));
} else {
disp.dispatch("input", new WeightMessage(1));
}
if (j % 5 == 1) {
ThreadUtil.sleep(1);
}
}
}
group.list();
System.out.println("Stage 2 - dispatch 1K/s, 1(1ms) : 1(10ms) weight messages; for 30 sec.");
for (int i = 0; i < 30; ++i) {
for (int j = 0; j < 1000; ++j) {
if (j % 2 == 1) {
disp.dispatch("input", new WeightMessage(10));
} else {
disp.dispatch("input", new WeightMessage(1));
}
ThreadUtil.sleep(1);
}
}
group.list();
System.out.println("Stage 3 - dispatch 10K/s, 1(1ms) : 1(10ms) weight messages; for 30 sec.");
for (int i = 0; i < 30; ++i) {
for (int j = 0; j < 10000; ++j) {
if (j % 2 == 1) {
disp.dispatch("input", new WeightMessage(10));
} else {
disp.dispatch("input", new WeightMessage(1));
}
if (j % 10 == 1) {
ThreadUtil.sleep(1);
}
}
}
group.list();
System.out.println("Stage 4 - dispatch 10K/s, 1(1ms) : 1(3ms) weight messages; for 30 sec.");
for (int i = 0; i < 30; ++i) {
for (int j = 0; j < 10000; ++j) {
if (j % 2 == 1) {
disp.dispatch("input", new WeightMessage(3));
} else {
disp.dispatch("input", new WeightMessage(1));
}
if (j % 10 == 1) {
ThreadUtil.sleep(1);
}
}
}
group.list();
ThreadUtil.sleep(2000);
System.out.println("Done.");
sw.done();
sw.print();
disp.shutdown();
ThreadUtil.sleep(2000);
group.list();
}