|
|
|
@ -3,14 +3,12 @@ package cn.hippo4j.example.inittest;
|
|
|
|
|
import cn.hippo4j.example.constant.GlobalTestConstant;
|
|
|
|
|
import cn.hippo4j.starter.core.GlobalThreadPoolManage;
|
|
|
|
|
import cn.hippo4j.starter.wrapper.DynamicThreadPoolWrapper;
|
|
|
|
|
import cn.hutool.core.thread.ThreadUtil;
|
|
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
|
|
|
|
import java.util.Random;
|
|
|
|
|
import java.util.concurrent.Executors;
|
|
|
|
|
import java.util.concurrent.ScheduledExecutorService;
|
|
|
|
|
import java.util.concurrent.ThreadPoolExecutor;
|
|
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Test run time metrics.
|
|
|
|
@ -27,8 +25,9 @@ public class RunStateHandlerTest {
|
|
|
|
|
public void runStateHandlerTest() {
|
|
|
|
|
log.info("Test thread pool runtime state interface, The rejection policy will be triggered after 30s...");
|
|
|
|
|
|
|
|
|
|
ScheduledExecutorService scheduledThreadPool = Executors.newSingleThreadScheduledExecutor();
|
|
|
|
|
scheduledThreadPool.scheduleAtFixedRate(() -> {
|
|
|
|
|
new Thread(() -> {
|
|
|
|
|
ThreadUtil.sleep(5000);
|
|
|
|
|
for (int i = 0; i < Integer.MAX_VALUE; i++) {
|
|
|
|
|
DynamicThreadPoolWrapper poolWrapper = GlobalThreadPoolManage.getExecutorService(GlobalTestConstant.MESSAGE_PRODUCE);
|
|
|
|
|
ThreadPoolExecutor pool = poolWrapper.getPool();
|
|
|
|
|
try {
|
|
|
|
@ -52,7 +51,11 @@ public class RunStateHandlerTest {
|
|
|
|
|
// ignore
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}, 5, 2, TimeUnit.SECONDS);
|
|
|
|
|
log.info(" >>> Number of dynamic thread pool tasks executed :: {}", i);
|
|
|
|
|
ThreadUtil.sleep(500);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}).start();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|