|
@@ -1,49 +1,49 @@
|
|
|
-package com.usky.iot.service.config;
|
|
|
-
|
|
|
-import lombok.extern.slf4j.Slf4j;
|
|
|
-import org.springframework.context.annotation.Bean;
|
|
|
-import org.springframework.context.annotation.Configuration;
|
|
|
-import org.springframework.scheduling.annotation.EnableAsync;
|
|
|
-import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
|
|
|
-
|
|
|
-import java.util.concurrent.Executor;
|
|
|
-import java.util.concurrent.ThreadPoolExecutor;
|
|
|
-
|
|
|
-@Configuration
|
|
|
-@EnableAsync
|
|
|
-@Slf4j
|
|
|
-public class ExecutorConfig {
|
|
|
-
|
|
|
-
|
|
|
- private int corePoolSize = 10;
|
|
|
-
|
|
|
- private int maxPoolSize = 20;
|
|
|
-
|
|
|
- private static final int keepAliveTime = 60;
|
|
|
-
|
|
|
- private int queueCapacity = 10;
|
|
|
-
|
|
|
- @Bean(name = "asyncServiceExecutor")
|
|
|
- public Executor asyncServiceExecutor(){
|
|
|
- log.info("start asyncServiceExecutor++++++++++++++++++++++");
|
|
|
- ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
|
|
|
-
|
|
|
- executor.setCorePoolSize(corePoolSize);
|
|
|
-
|
|
|
- executor.setMaxPoolSize(maxPoolSize);
|
|
|
-
|
|
|
- executor.setKeepAliveSeconds(keepAliveTime);
|
|
|
-
|
|
|
- executor.setQueueCapacity(queueCapacity);
|
|
|
-
|
|
|
- executor.setThreadNamePrefix("async-service-");
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
|
|
|
-
|
|
|
-
|
|
|
- executor.initialize();
|
|
|
- return executor;
|
|
|
- }
|
|
|
-}
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|