欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年04月18日 15:16:57   作者:何亦冷  
這篇文章主要介紹了SpringBoot項(xiàng)目@Async方法問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

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

2. SpringMonitor的配置屬性

3. SpringMonitor的Threads

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

相關(guān)文章

  • java中的取整與四舍五入方法實(shí)例

    java中的取整與四舍五入方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于java中取整與四舍五入的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Java面試題沖刺第七天--Spring框架1

    Java面試題沖刺第七天--Spring框架1

    這篇文章主要為大家分享了最有價值的三道Spring框架面試題,涵蓋內(nèi)容全面,包括數(shù)據(jù)結(jié)構(gòu)和算法相關(guān)的題目、經(jīng)典面試編程題等,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Java中多線程同步類 CountDownLatch

    Java中多線程同步類 CountDownLatch

    本篇文章主要介紹了Java中多線程同步類 CountDownLatch的相關(guān)知識,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-05-05
  • druid?handleException執(zhí)行流程源碼解析

    druid?handleException執(zhí)行流程源碼解析

    這篇文章主要為大家介紹了druid?handleException執(zhí)行流程源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • java實(shí)現(xiàn)HmacSHA256算法進(jìn)行加密方式

    java實(shí)現(xiàn)HmacSHA256算法進(jìn)行加密方式

    這篇文章主要介紹了java實(shí)現(xiàn)HmacSHA256算法進(jìn)行加密方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • idea配置gradle全過程

    idea配置gradle全過程

    安裝Gradle首先需要解壓安裝包到指定目錄,隨后配置環(huán)境變量GRDLE_HOME和GRADLE_USER_HOME,這里的GRADLE_USER_HOME是指文件下載的路徑,安裝后,通過命令行輸入gradle -v來測試是否安裝成功,對于Idea的配置,需要通過File->Setting->Gradle進(jìn)行
    2024-10-10
  • 使用mybatisPlus生成oracle自增序列遇到的坑及解決

    使用mybatisPlus生成oracle自增序列遇到的坑及解決

    這篇文章主要介紹了使用mybatisPlus生成oracle自增序列遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Java如何用時間戳重命名上傳的文件

    Java如何用時間戳重命名上傳的文件

    這篇文章主要介紹了Java如何用時間戳重命名上傳的文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • java 文件名截取方法

    java 文件名截取方法

    在實(shí)際開發(fā)應(yīng)用中會應(yīng)到截取文件名,本文將介紹java中文件名的截取,需要了解的朋友可以參考下
    2012-11-11
  • java Nio使用NioSocket客戶端與服務(wù)端交互實(shí)現(xiàn)方式

    java Nio使用NioSocket客戶端與服務(wù)端交互實(shí)現(xiàn)方式

    這篇文章主要介紹了java Nio使用 NioSocket 客戶端與服務(wù)端交互實(shí)現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06

最新評論