国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

SpringBoot項目@Async方法問題解決方案

瀏覽:2日期:2023-05-23 13:57:03

現(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)建新線程的條件是隊列填滿時, 而這樣的配置隊列永遠不會填滿, 如果有@Async注解標(biāo)注的方法長期占用線程(比如HTTP長連接等待獲取結(jié)果), 在核心8個線程數(shù)占用滿了之后, 新的調(diào)用就會進入隊列, 外部表現(xiàn)為沒有執(zhí)行.

解決:

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

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

備注:

此處沒有配置maxSize, 仍是默認(rèn)的Integer.MAX_VALUE. 如果配置的話, 請考慮達到最大線程數(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方法問題解決方案

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 亚洲网站免费观看 | 欧美一级片免费观看 | 国产精品久久久久久久久久久搜索 | 中国美女一级片 | 精品国产中文一级毛片在线看 | 91久久夜色精品国产网站 | 男的操美女 | 日本一区二区三区四区不卡 | 国产精品反差婊在线观看 | 久久精品国产99国产 | 美国全免费特一级毛片 | 日本精高清区一 | 免费国产成人 | 成人合成mv福利视频网站 | 国内精品久久久久影院网站 | 免费观看一级特黄三大片视频 | 久草在线中文最新视频 | 成人手机看片 | 国产一毛片 | 福利一二三区 | 午夜日b视频 | 国产高清在线精品一区二区三区 | 亚洲精品片 | 亚洲激情视频网站 | 日本伊人精品一区二区三区 | 日韩一区国产二区欧美三区 | 欧美成人鲁丝片在线观看 | 亚洲男人精品 | 九九在线观看精品视频6 | 国产亚洲精品看片在线观看 | 欧美一区二区三区高清视频 | 另类视频区第一页 | 一区二区三区高清不卡 | 黄网站www | 韩国一级黄色大片 | 国产一级强片在线观看 | 91在线精品亚洲一区二区 | 精品玖玖玖视频在线观看 | 国产美女精品视频免费观看 | 三级手机在线观看 | 亚洲精品亚洲人成在线麻豆 |