spring中的線程池

org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor是spring提供的線程池類

/**
 * @author Jenson 2020-08-18
 */
@Configuration
@EnableAsync
public class AsyncConfiguration {
    /**
     * 聲明一個(gè)線程池
     *
     * @return 執(zhí)行器
     */
    @Bean("executorBeanName")
    public Executor asyncExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        //通過Runtime方法來獲取當(dāng)前服務(wù)器cpu內(nèi)核,根據(jù)cpu內(nèi)核來創(chuàng)建核心線程數(shù)和最大線程數(shù)
        int threadCount = Runtime.getRuntime().availableProcessors();
        //核心線程數(shù)5:線程池創(chuàng)建時(shí)候初始化的線程數(shù)(核心線程數(shù)最大不超過)
        executor.setCorePoolSize(5);
        //最大線程數(shù)5:線程池最大的線程數(shù)银还,只有在緩沖隊(duì)列滿了之后才會申請超過核心線程數(shù)的線程
        executor.setMaxPoolSize(5);
        //緩沖隊(duì)列500:用來緩沖執(zhí)行任務(wù)的隊(duì)列
        executor.setQueueCapacity(500);
        //允許線程的空閑時(shí)間60秒:當(dāng)超過了核心線程出之外的線程在空閑時(shí)間到達(dá)之后會被銷毀
        executor.setKeepAliveSeconds(60);
        //線程池名的前綴:設(shè)置好了之后可以方便我們定位處理任務(wù)所在的線程池
        executor.setThreadNamePrefix("async01-");
        //配置拒絕策略状原,線程池對拒絕任務(wù)(無線程可用)的處理策略 
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.AbortPolicy());//配置拒絕策略
        executor.initialize();
        return executor;
    }
}

拒絕策略:

AbortPolicy:用于被拒絕任務(wù)的處理程序爷光,它將拋出RejectedExecutionException

CallerRunsPolicy:用于被拒絕任務(wù)的處理程序强衡,它直接在execute方法的調(diào)用線程中運(yùn)行被拒絕的任務(wù)端盆。

DiscardOldestPolicy:用于被拒絕任務(wù)的處理程序闪幽,它放棄最舊的未處理請求料皇,然后重試execute谓松。

DiscardPolicy:用于被拒絕任務(wù)的處理程序星压,默認(rèn)情況下它將丟棄被拒絕的任務(wù)。

執(zhí)行過程:

如果此時(shí)線程池中的數(shù)量小于corePoolSize鬼譬,即使線程池中的線程都處于空閑狀態(tài)娜膘,也要?jiǎng)?chuàng)建新的線程來處理被添加的任務(wù)。

如果此時(shí)線程池中的數(shù)量等于 corePoolSize优质,但是緩沖隊(duì)列 workQueue未滿竣贪,那么任務(wù)被放入緩沖隊(duì)列。

如果此時(shí)線程池中的數(shù)量大于corePoolSize巩螃,緩沖隊(duì)列workQueue滿演怎,并且線程池中的數(shù)量小于maxPoolSize,建新的線程來處理被添加的任務(wù)避乏。

如果此時(shí)線程池中的數(shù)量大于corePoolSize爷耀,緩沖隊(duì)列workQueue滿,并且線程池中的數(shù)量等于maxPoolSize拍皮,那么通過handler所指定的策略來處理此任務(wù)歹叮。也就是:處理任務(wù)的優(yōu)先級為:核心線程corePoolSize、任務(wù)隊(duì)列workQueue铆帽、最大線程 maximumPoolSize咆耿,如果三者都滿了,使用handler處理被拒絕的任務(wù)锄贼。

當(dāng)線程池中的線程數(shù)量大于corePoolSize時(shí)票灰,如果某線程空閑時(shí)間超過keepAliveTime,線程將被終止宅荤。這樣屑迂,線程池可以動態(tài)的調(diào)整池中的線程數(shù)。

核心線程數(shù)設(shè)置參考:
CPU密集型:核心線程數(shù) = CPU核數(shù) + 1
IO密集型:核心線程數(shù) = CPU核數(shù) * 2

什么是CPU密集型冯键?什么是IO密集型惹盼?
https://blog.csdn.net/youanyyou/article/details/78990156
CPU密集型也叫計(jì)算密集型,計(jì)算密集型任務(wù)的特點(diǎn)是要進(jìn)行大量的計(jì)算惫确,消耗CPU資源手报,這種計(jì)算密集型任務(wù)雖然也可以用多任務(wù)完成,但是任務(wù)越多改化,花在任務(wù)切換的時(shí)間就越多掩蛤,CPU執(zhí)行任務(wù)的效率就越低,所以陈肛,要最高效地利用CPU揍鸟,計(jì)算密集型任務(wù)同時(shí)進(jìn)行的數(shù)量應(yīng)當(dāng)?shù)扔贑PU的核心數(shù)。
IO密集型句旱,涉及到網(wǎng)絡(luò)阳藻、磁盤IO的任務(wù)都是IO密集型任務(wù)晰奖,這類任務(wù)的特點(diǎn)是CPU消耗很少,任務(wù)的大部分時(shí)間都在等待IO操作完成(因?yàn)镮O的速度遠(yuǎn)遠(yuǎn)低于CPU和內(nèi)存的速度)腥泥。對于IO密集型任務(wù)匾南,任務(wù)越多,CPU效率越高蛔外,但也有一個(gè)限度蛆楞。

參考:
https://blog.csdn.net/weixin_43168010/article/details/97613895

https://www.cnblogs.com/redcool/p/6426173.html

https://blog.csdn.net/lifulian318/article/details/109000675

補(bǔ)充:拒絕策略使用場景和其他第三方拒絕策略,參考:https://blog.csdn.net/zj57356498318/article/details/102579980

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末冒萄,一起剝皮案震驚了整個(gè)濱河市臊岸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌尊流,老刑警劉巖帅戒,帶你破解...
    沈念sama閱讀 218,036評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異崖技,居然都是意外死亡逻住,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評論 3 395
  • 文/潘曉璐 我一進(jìn)店門迎献,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瞎访,“玉大人,你說我怎么就攤上這事吁恍“墙眨” “怎么了?”我有些...
    開封第一講書人閱讀 164,411評論 0 354
  • 文/不壞的土叔 我叫張陵冀瓦,是天一觀的道長伴奥。 經(jīng)常有香客問我,道長翼闽,這世上最難降的妖魔是什么拾徙? 我笑而不...
    開封第一講書人閱讀 58,622評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮感局,結(jié)果婚禮上尼啡,老公的妹妹穿的比我還像新娘。我一直安慰自己询微,他們只是感情好崖瞭,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著撑毛,像睡著了一般书聚。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,521評論 1 304
  • 那天寺惫,我揣著相機(jī)與錄音,去河邊找鬼蹦疑。 笑死西雀,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的歉摧。 我是一名探鬼主播艇肴,決...
    沈念sama閱讀 40,288評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼叁温!你這毒婦竟也來了再悼?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,200評論 0 276
  • 序言:老撾萬榮一對情侶失蹤膝但,失蹤者是張志新(化名)和其女友劉穎冲九,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體跟束,經(jīng)...
    沈念sama閱讀 45,644評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡莺奸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了冀宴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片灭贷。...
    茶點(diǎn)故事閱讀 39,953評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖略贮,靈堂內(nèi)的尸體忽然破棺而出甚疟,到底是詐尸還是另有隱情,我是刑警寧澤逃延,帶...
    沈念sama閱讀 35,673評論 5 346
  • 正文 年R本政府宣布览妖,位于F島的核電站,受9級特大地震影響真友,放射性物質(zhì)發(fā)生泄漏黄痪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評論 3 329
  • 文/蒙蒙 一盔然、第九天 我趴在偏房一處隱蔽的房頂上張望桅打。 院中可真熱鬧,春花似錦愈案、人聲如沸挺尾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽遭铺。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間魂挂,已是汗流浹背甫题。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留涂召,地道東北人坠非。 一個(gè)月前我還...
    沈念sama閱讀 48,119評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像果正,于是被迫代替她去往敵國和親炎码。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評論 2 355

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