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

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

SpringBoot項(xiàng)目@Async方法問題解決方案

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

現(xiàn)象:

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

2. 分析現(xiàn)象: 日志中某個(gè)時(shí)刻之后沒有了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)注的方法長期占用線程(比如HTTP長連接等待獲取結(jié)果), 在核心8個(gè)線程數(shù)占用滿了之后, 新的調(diào)用就會(huì)進(jìn)入隊(duì)列, 外部表現(xiàn)為沒有執(zhí)行.

解決:

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

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

備注:

此處沒有配置maxSize, 仍是默認(rèn)的Integer.MAX_VALUE. 如果配置的話, 請考慮達(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

SpringBoot項(xiàng)目@Async方法問題解決方案

2. SpringMonitor的配置屬性

SpringBoot項(xiàng)目@Async方法問題解決方案

3. SpringMonitor的Threads

SpringBoot項(xiàng)目@Async方法問題解決方案

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

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 成年片免费网址网站 | 2020国产微拍精品一区二区 | 欧美成人亚洲 | 99久久精品国产一区二区三区 | 成人精品免费网站 | 成人亚洲网 | 国产亚洲精品国产一区 | 国产日韩欧美综合在线 | 操爽视频| 亚洲日本视频 | 国产成人午夜 | 国产综合第一页 | 久久午夜精品 | 国产成人亚洲综合91精品555 | 欧美精品久久久亚洲 | 日韩性网站| 国产精品欧美激情在线播放 | 九久久 | 一级a毛片免费 | 国产午夜精品久久理论片小说 | 视频网18免费 | 久草网首页 | 日韩 综合 | 手机看片1024久久精品你懂的 | 黄色福利网 | 亚洲国产一区二区在线 | 一级做a爰片久久毛片美女 一级做a爰片久久毛片免费看 | 成年人在线观看网站 | 成人免费看黄网址 | 精品久久久中文字幕一区 | 国产成人免费手机在线观看视频 | 国产女厕偷窥系列在线视频 | 国产欧美日韩亚洲精品区2345 | 日本aaaaa级毛片 | 午夜影院美女 | 成人精品一区久久久久 | 69性欧美 | 久草久草视频 | 亚洲国产第一 | 免费在线观看a级毛片 | 国产在线精品一区二区三区不卡 |