溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

解決SpringBoot項目@Async方法問題

發(fā)布時間:2020-08-03 09:29:41 來源:億速云 閱讀:186 作者:小豬 欄目:編程語言

小編這次要給大家分享的是解決SpringBoot項目@Async方法問題,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

現(xiàn)象:

1. 表面現(xiàn)象: 方法中輸出的日志, 日志文件中找不到, 也沒有任何報錯(即@Async標(biāo)注的方法沒有執(zhí)行, 也沒有報錯)

2. 分析現(xiàn)象: 日志中某個時刻之后沒有了task-xxx線程的日志

原因:

@Async異常方法默認(rèn)使用Spring創(chuàng)建ThreadPoolTaskExecutor(參考TaskExecutionAutoConfiguration),

其中默認(rèn)核心線程數(shù)為8, 默認(rèn)最大隊列和默認(rèn)最大線程數(shù)都是Integer.MAX_VALUE. 創(chuàng)建新線程的條件是隊列填滿時, 而這樣的配置隊列永遠(yuǎn)不會填滿, 如果有@Async注解標(biāo)注的方法長期占用線程(比如HTTP長連接等待獲取結(jié)果), 在核心8個線程數(shù)占用滿了之后, 新的調(diào)用就會進入隊列, 外部表現(xiàn)為沒有執(zhí)行.

解決:

手動配置相應(yīng)屬性即可. 比如

spring.task.execution.pool.queueCapacity=4
spring.task.execution.pool.coreSize=20

備注:

此處沒有配置maxSize, 仍是默認(rèn)的Integer.MAX_VALUE. 如果配置的話, 請考慮達(dá)到最大線程數(shù)時的處理策略(JUC包查找RejectedExecutionHandler的實現(xiàn)類)

(默認(rèn)為拒絕執(zhí)行AbortPolicy, 即拋出異常)

AbortPolicy: 直接拋出java.util.concurrent.RejectedExecutionException異常

CallerRunsPolicy: 主線程直接執(zhí)行該任務(wù),執(zhí)行完之后嘗試添加下一個任務(wù)到線程池中,可以有效降低向線程池內(nèi)添加任務(wù)的速度

DiscardOldestPolicy: 拋棄舊的任務(wù)

DiscardPolicy: 拋棄當(dāng)前任務(wù)

截圖:

1. ThreadPoolTaskExecutor

解決SpringBoot項目@Async方法問題

2. SpringMonitor的配置屬性

解決SpringBoot項目@Async方法問題

3. SpringMonitor的Threads

解決SpringBoot項目@Async方法問題

看完這篇關(guān)于解決SpringBoot項目@Async方法問題的文章,如果覺得文章內(nèi)容寫得不錯的話,可以把它分享出去給更多人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI