diff --git a/src/main/java/com/genersoft/iot/vmp/conf/ThreadPoolTaskConfig.java b/src/main/java/com/genersoft/iot/vmp/conf/ThreadPoolTaskConfig.java index 1dfd591e..2ef33230 100644 --- a/src/main/java/com/genersoft/iot/vmp/conf/ThreadPoolTaskConfig.java +++ b/src/main/java/com/genersoft/iot/vmp/conf/ThreadPoolTaskConfig.java @@ -11,6 +11,8 @@ import java.util.concurrent.ThreadPoolExecutor; @EnableAsync(proxyTargetClass = true) public class ThreadPoolTaskConfig { + public static final int cpuNum = Runtime.getRuntime().availableProcessors(); + /** * 默认情况下,在创建了线程池后,线程池中的线程数为0,当有任务来之后,就会创建一个线程去执行任务, * 当线程池中的线程数目达到corePoolSize后,就会把到达的任务放到缓存队列当中; @@ -20,11 +22,11 @@ public class ThreadPoolTaskConfig { /** * 核心线程数(默认线程数) */ - private static final int corePoolSize = 5; + private static final int corePoolSize = cpuNum; /** * 最大线程数 */ - private static final int maxPoolSize = 30; + private static final int maxPoolSize = cpuNum*2; /** * 允许线程空闲时间(单位:默认为秒) */ @@ -32,7 +34,7 @@ public class ThreadPoolTaskConfig { /** * 缓冲队列大小 */ - private static final int queueCapacity = 10000; + private static final int queueCapacity = 500; /** * 线程池名前缀 */