SpringBoot項目@Async方法問題解決方案
現(xiàn)象:
1. 表面現(xiàn)象: 方法中輸出的日志, 日志文件中找不到, 也沒有任何報錯(即@Async標注的方法沒有執(zhí)行, 也沒有報錯)
2. 分析現(xiàn)象: 日志中某個時刻之后沒有了task-xxx線程的日志
原因:
@Async異常方法默認使用Spring創(chuàng)建ThreadPoolTaskExecutor(參考TaskExecutionAutoConfiguration),
其中默認核心線程數(shù)為8, 默認最大隊列和默認最大線程數(shù)都是Integer.MAX_VALUE. 創(chuàng)建新線程的條件是隊列填滿時, 而這樣的配置隊列永遠不會填滿, 如果有@Async注解標注的方法長期占用線程(比如HTTP長連接等待獲取結果), 在核心8個線程數(shù)占用滿了之后, 新的調用就會進入隊列, 外部表現(xiàn)為沒有執(zhí)行.
解決:
手動配置相應屬性即可. 比如
spring.task.execution.pool.queueCapacity=4
spring.task.execution.pool.coreSize=20
備注:
此處沒有配置maxSize, 仍是默認的Integer.MAX_VALUE. 如果配置的話, 請考慮達到最大線程數(shù)時的處理策略(JUC包查找RejectedExecutionHandler的實現(xiàn)類)
(默認為拒絕執(zhí)行AbortPolicy, 即拋出異常)
AbortPolicy: 直接拋出java.util.concurrent.RejectedExecutionException異常
CallerRunsPolicy: 主線程直接執(zhí)行該任務,執(zhí)行完之后嘗試添加下一個任務到線程池中,可以有效降低向線程池內添加任務的速度
DiscardOldestPolicy: 拋棄舊的任務
DiscardPolicy: 拋棄當前任務
截圖:
1. ThreadPoolTaskExecutor
2. SpringMonitor的配置屬性
3. SpringMonitor的Threads
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
druid?handleException執(zhí)行流程源碼解析
這篇文章主要為大家介紹了druid?handleException執(zhí)行流程源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09java實現(xiàn)HmacSHA256算法進行加密方式
這篇文章主要介紹了java實現(xiàn)HmacSHA256算法進行加密方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08使用mybatisPlus生成oracle自增序列遇到的坑及解決
這篇文章主要介紹了使用mybatisPlus生成oracle自增序列遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03java Nio使用NioSocket客戶端與服務端交互實現(xiàn)方式
這篇文章主要介紹了java Nio使用 NioSocket 客戶端與服務端交互實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06