廢話少說,直接上代碼
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.core.task.AsyncTaskExecutor; import org.springframework.scheduling.annotation.EnableAsync; import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; import java.util.concurrent.*; @Configuration @EnableAsync public class SpringAsyncConfig { @Bean("taskExecutor") public Executor asyncServiceExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); // 設置核心線程數 executor.setCorePoolSize(5); // 設置最大線程數 executor.setMaxPoolSize(20); //配置隊列大小 executor.setQueueCapacity(Integer.MAX_VALUE); // 設置線程活躍時間(秒) executor.setKeepAliveSeconds(60); // 設置默認線程名稱 executor.setThreadNamePrefix("獲取旺旺信息"); // 等待所有任務結束后再關閉線程池 executor.setWaitForTasksToCompleteOnShutdown(true); //執行初始化 executor.initialize(); return executor; } }
controller層
import com.yzx.caasscs.controller.BaseController; import com.yzx.caasscs.service.Thread.AsyncService; import com.yzx.caasscs.vo.ResultVO; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; /** * @author qjwyss * @date 2018/10/12 * @description */ @RestController public class ThreadController extends BaseController { private static final Logger logger = LoggerFactory.getLogger(ThreadController.class); @Autowired private AsyncService asyncService; @GetMapping("/sss") public ResultVO<Void> sss(){ //調用service層的任務 asyncService.executeAsync(); return ResultVO.getSuccess("OK"); } }
service
public interface AsyncService { /** * 執行異步任務 */ void executeAsync(); }
serviceImpl
import com.yzx.caasscs.service.Thread.AsyncService; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; @Service public class AsyncServiceImpl implements AsyncService { private static final Logger logger = LoggerFactory.getLogger(AsyncServiceImpl.class); @Async("taskExecutor") @Override public void executeAsync() { logger.info("start executeAsync"); try { System.out.println("當前運行的線程名稱:" + Thread.currentThread().getName()); } catch (Exception e) { e.printStackTrace(); } logger.info("end executeAsync"); } }
@Async和@EnableAsync要結合使用,才能發揮異步的效果
建議把所有帶有@Async的方法都放到同一個類里,不然很容易出現循環依賴的問題