色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

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

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

現象:

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

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

原因:

@Async異常方法默認使用Spring創建ThreadPoolTaskExecutor(參考TaskExecutionAutoConfiguration),

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

解決:

手動配置相應屬性即可. 比如

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

備注:

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

(默認為拒絕執行AbortPolicy, 即拋出異常)

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

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

DiscardOldestPolicy: 拋棄舊的任務

DiscardPolicy: 拋棄當前任務

截圖:

1. ThreadPoolTaskExecutor

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

2. SpringMonitor的配置屬性

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

3. SpringMonitor的Threads

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 久久99精品久久久久久久野外 | 99re5久久在热线播放 | 浮力影院网站午夜 | 日韩 国产 欧美 | 国产大尺度福利视频在线观看 | 亚洲免费在线视频播放 | 亚洲在线视频免费 | 久色国产 | 98国内自拍在线视频 | 足恋玩丝袜脚视频免费网站 | 久草网视频在线观看 | 手机看片手机在线看片 | 成人亚洲网站 | 国内精自品线一区91 | 久久频这里精品99香蕉久 | 日本加勒比在线观看 | 国产2页 | 三级黄色片日韩 | 黄在线网站 | 久久久久久极精品久久久 | 女人扒开双腿让男人捅 | 热99re久久国超精品首页 | 二区在线观看 | 黄色毛片一级 | 欧美激情久久久久久久久 | 亚洲国产精品免费观看 | 免费视频久久久 | 深夜成人性视频免费看 | 欧美特黄一级aa毛片 | 美女张开腿给男人捅 | 亚洲人在线播放 | 一级做人爱a视频正版免费 一级做性色a爱片久久片 | 欧美成人猛男性色生活 | 成人看片黄a毛片 | 国产欧美另类久久精品91 | 国产一区二区三区日韩欧美 | 亚洲高清一区二区三区四区 | 男女在线视频 | 国产a精品三级 | 免费a级在线观看播放 | 国产成人亚洲综合欧美一部 |