SpringBoot使用@Async實(shí)現(xiàn)異步調(diào)用:自定義線程池

定義線程池
  • 在Spring Boot主類中定義一個(gè)線程池奸腺,比如:
@SpringBootApplication
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

    @EnableAsync
    @Configuration
    class TaskPoolConfig {
        @Bean("taskExecutor")
        public Executor taskExecutor() {
            ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
            executor.setCorePoolSize(10);
            executor.setMaxPoolSize(20);
            executor.setQueueCapacity(200);
            executor.setKeepAliveSeconds(60);
            executor.setThreadNamePrefix("taskExecutor-");
            executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
            executor.setWaitForTasksToCompleteOnShutdown(true);
            executor.setAwaitTerminationSeconds(60);
            return executor;
        }
    }
}

上面我們通過ThreadPoolTaskExecutor創(chuàng)建了一個(gè)線程池,同時(shí)設(shè)置了如下參數(shù):

  • 核心線程數(shù)10:線程池創(chuàng)建時(shí)初始化的線程數(shù)
  • 最大線程數(shù)20:線程池最大的線程數(shù)梯投,只有在緩沖隊(duì)列滿了之后才會(huì)申請(qǐng)超過核心線程數(shù)的線程
  • 緩沖隊(duì)列200:用來緩沖執(zhí)行任務(wù)的隊(duì)列
  • 允許線程的空閑時(shí)間60秒:超過了核心線程數(shù)之外的線程桐臊,在空閑時(shí)間到達(dá)之后會(huì)被銷毀
  • 線程池名的前綴:設(shè)置好了之后可以方便我們定位處理任務(wù)所在的線程池
  • 線程池對(duì)拒絕任務(wù)的處理策略:此處采用了CallerRunsPolicy策略轴合,當(dāng)線程池沒有處理能力的時(shí)候虐秦,該策略會(huì)直接在execute方法的調(diào)用線程中運(yùn)行被拒絕的任務(wù)平酿;如果執(zhí)行程序已被關(guān)閉,則會(huì)丟棄該任務(wù)
  • 設(shè)置線程池關(guān)閉的時(shí)候等待所有任務(wù)都完成再繼續(xù)銷毀其他的Bean
  • 設(shè)置線程池中任務(wù)的等待時(shí)間羡疗,如果超過這個(gè)時(shí)候還沒有銷毀就強(qiáng)制銷毀染服,以確保應(yīng)用最后能夠被關(guān)閉,而不是阻塞住
使用線程池
  • 只需要在@Async注解中指定線程池名即可
@Slf4j
@Component
public class Task {

    public static Random random = new Random();

    @Async("taskExecutor")
    public void doTaskOne() throws Exception {
        log.info("開始做任務(wù)一");
        long start = System.currentTimeMillis();
        Thread.sleep(random.nextInt(10000));
        long end = System.currentTimeMillis();
        log.info("完成任務(wù)一叨恨,耗時(shí):" + (end - start) + "毫秒");
    }

    @Async("taskExecutor")
    public void doTaskTwo() throws Exception {
        log.info("開始做任務(wù)二");
        long start = System.currentTimeMillis();
        Thread.sleep(random.nextInt(10000));
        long end = System.currentTimeMillis();
        log.info("完成任務(wù)二,耗時(shí):" + (end - start) + "毫秒");
    }

    @Async("taskExecutor")
    public void doTaskThree() throws Exception {
        log.info("開始做任務(wù)三");
        long start = System.currentTimeMillis();
        Thread.sleep(random.nextInt(10000));
        long end = System.currentTimeMillis();
        log.info("完成任務(wù)三挖垛,耗時(shí):" + (end - start) + "毫秒");
    }
}
  • 測(cè)試
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest
public class ApplicationTests {

    @Autowired
    private Task task;

    @Test
    public void test() throws Exception {

        task.doTaskOne();
        task.doTaskTwo();
        task.doTaskThree();
        Thread.currentThread().join();
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末痒钝,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子痢毒,更是在濱河造成了極大的恐慌送矩,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哪替,死亡現(xiàn)場離奇詭異栋荸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門晌块,熙熙樓的掌柜王于貴愁眉苦臉地迎上來爱沟,“玉大人,你說我怎么就攤上這事匆背『羯欤” “怎么了?”我有些...
    開封第一講書人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵钝尸,是天一觀的道長括享。 經(jīng)常有香客問我,道長珍促,這世上最難降的妖魔是什么铃辖? 我笑而不...
    開封第一講書人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮猪叙,結(jié)果婚禮上澳叉,老公的妹妹穿的比我還像新娘。我一直安慰自己沐悦,他們只是感情好成洗,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著藏否,像睡著了一般瓶殃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上副签,一...
    開封第一講書人閱讀 49,950評(píng)論 1 291
  • 那天遥椿,我揣著相機(jī)與錄音,去河邊找鬼淆储。 笑死冠场,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的本砰。 我是一名探鬼主播碴裙,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼点额!你這毒婦竟也來了舔株?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤还棱,失蹤者是張志新(化名)和其女友劉穎载慈,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體珍手,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡办铡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年辞做,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片寡具。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡秤茅,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出晒杈,到底是詐尸還是另有隱情嫂伞,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布拯钻,位于F島的核電站帖努,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏粪般。R本人自食惡果不足惜拼余,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望亩歹。 院中可真熱鬧匙监,春花似錦、人聲如沸小作。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽顾稀。三九已至达罗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間静秆,已是汗流浹背粮揉。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留抚笔,地道東北人扶认。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像殊橙,于是被迫代替她去往敵國和親辐宾。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容

  • 為什么使用線程池 當(dāng)我們?cè)谑褂镁€程時(shí)蛀柴,如果每次需要一個(gè)線程時(shí)都去創(chuàng)建一個(gè)線程螃概,這樣實(shí)現(xiàn)起來很簡單,但是會(huì)有一個(gè)問題...
    閩越布衣閱讀 4,281評(píng)論 10 45
  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時(shí)...
    歐辰_OSR閱讀 29,340評(píng)論 8 265
  • DAY 2/21 43-登登-內(nèi)容制作 【今日讀書】:《窮查理寶典》第二章:芒格的生活鸽疾、學(xué)習(xí)和決策方法 【今日讀書...
    登登登Veronica閱讀 338評(píng)論 0 0
  • 2018.3.13 周二 晴 宋雨宸 今天是個(gè)好日子,大好的晴天溫度到了28度训貌,我的隨心情隨之也高了起...
    宋雨宸媽媽閱讀 200評(píng)論 0 0