小編這次要給大家分享的是解決SpringBoot項(xiàng)目@Async方法問(wèn)題,文章內(nèi)容豐富,感興趣的小伙伴可以來(lái)了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
創(chuàng)新互聯(lián)主要從事成都網(wǎng)站建設(shè)、成都做網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)平邑,十余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):18980820575現(xiàn)象:
1. 表面現(xiàn)象: 方法中輸出的日志, 日志文件中找不到, 也沒(méi)有任何報(bào)錯(cuò)(即@Async標(biāo)注的方法沒(méi)有執(zhí)行, 也沒(méi)有報(bào)錯(cuò))
2. 分析現(xiàn)象: 日志中某個(gè)時(shí)刻之后沒(méi)有了task-xxx線程的日志
原因:
@Async異常方法默認(rèn)使用Spring創(chuàng)建ThreadPoolTaskExecutor(參考TaskExecutionAutoConfiguration),
其中默認(rèn)核心線程數(shù)為8, 默認(rèn)大隊(duì)列和默認(rèn)大線程數(shù)都是Integer.MAX_VALUE. 創(chuàng)建新線程的條件是隊(duì)列填滿時(shí), 而這樣的配置隊(duì)列永遠(yuǎn)不會(huì)填滿, 如果有@Async注解標(biāo)注的方法長(zhǎng)期占用線程(比如HTTP長(zhǎng)連接等待獲取結(jié)果), 在核心8個(gè)線程數(shù)占用滿了之后, 新的調(diào)用就會(huì)進(jìn)入隊(duì)列, 外部表現(xiàn)為沒(méi)有執(zhí)行.
解決:
手動(dòng)配置相應(yīng)屬性即可. 比如
spring.task.execution.pool.queueCapacity=4
spring.task.execution.pool.coreSize=20
備注:
此處沒(méi)有配置maxSize, 仍是默認(rèn)的Integer.MAX_VALUE. 如果配置的話, 請(qǐng)考慮達(dá)到大線程數(shù)時(shí)的處理策略(JUC包查找RejectedExecutionHandler的實(shí)現(xiàn)類)
(默認(rèn)為拒絕執(zhí)行AbortPolicy, 即拋出異常)
AbortPolicy: 直接拋出java.util.concurrent.RejectedExecutionException異常
CallerRunsPolicy: 主線程直接執(zhí)行該任務(wù),執(zhí)行完之后嘗試添加下一個(gè)任務(wù)到線程池中,可以有效降低向線程池內(nèi)添加任務(wù)的速度
DiscardOldestPolicy: 拋棄舊的任務(wù)
DiscardPolicy: 拋棄當(dāng)前任務(wù)
截圖:
1. ThreadPoolTaskExecutor
2. SpringMonitor的配置屬性
3. SpringMonitor的Threads
看完這篇關(guān)于解決SpringBoot項(xiàng)目@Async方法問(wèn)題的文章,如果覺(jué)得文章內(nèi)容寫(xiě)得不錯(cuò)的話,可以把它分享出去給更多人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.rwnh.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
分享文章:解決SpringBoot項(xiàng)目@Async方法問(wèn)題-創(chuàng)新互聯(lián)
新聞來(lái)源:http://www.rwnh.cn/article36/pdosg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、電子商務(wù)、用戶體驗(yàn)、Google、移動(dòng)網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容