<bdo id="4awyc"><del id="4awyc"></del></bdo>
  • <s id="4awyc"></s>
  • <tfoot id="4awyc"><small id="4awyc"></small></tfoot>
    <s id="4awyc"><acronym id="4awyc"></acronym></s>
  • <center id="4awyc"></center>
    <s id="4awyc"><acronym id="4awyc"></acronym></s>

    環球快資訊:性能提升 200% !SpringBoot 虛擬線程來了

    2023-06-24 14:54:00 來源: 程序員客棧

    在以往的項目中,我們面臨了這樣一種情況:我們收到了數千個認證請求。為了確保安全性,我們依靠第三方系統發送短信 OTP 進行驗證。然而,有時候第三方系統花費的時間比預期的要長,導致延遲。我們采用了每個請求一個線程的模型,這意味著許多線程處于等待狀態,并且新請求都在隊列中。我們試圖通過微調線程數量來優化性能,但當時我們希望有虛擬線程功能。當時 Java 中沒有虛擬線程的概念,這就是 Project Loom 的作用。

    虛擬線程
    什么是 Project Loom?

    什么是 Project Loom?這是 Oracle 的一個新項目,主要目標是顯著減少編寫、維護和觀察高吞吐量并發應用程序的工作量。換句話說,Project Loom 旨在支持和推進一個高吞吐量、輕量級的 Java 并發模型,因為傳統的操作系統線程(Java 并發模型的核心)有一些缺點,并且在計算上相當昂貴。反之,虛擬線程是更輕量級的線程,不與操作系統線程連接(由 JVM 管理)。這意味著虛擬線程是“每請求對應一個線程”編程的理想選擇,可以創建大量的虛擬線程,而不會降低吞吐量。開發人員可以使用現有的 JDK 工具和技術快速排除故障、調試和分析并發應用程序,在發布的 Spring Boot 3.1 中可用。作為 Spring 開發者,了解虛擬線程的概念并理解它們在開發過程中的重要性非常關鍵。


    【資料圖】

    如何使用虛擬線程Java 版本選擇

    Java 19 中引入的虛擬線程非常易于使用,筆者使用的 Mac M1 系列,這里選擇 Azul Zulu 發行版 20.30.11 版本[1]

    azul 20
    創建測試項目

    使用 Spring Initializer 或 IDE 創建項目。添加 spring-web 依賴項并添加元數據。(注意版本選擇 SpringBoot 3.1 ,Java 20)

    開啟虛擬線程功能
    默認報錯

    默認情況下, Java19 的虛擬線程功能是禁用狀態的,需要通過相關 maven 編譯配置開啟。

    org.springframework.bootspring-boot-maven-pluginorg.apache.maven.pluginsmaven-compiler-plugin--enable-preview

    通過配置 bean 啟用虛擬線程

    @Bean?TomcatProtocolHandlerCustomizerthreadExecutorCustomizer()?{??return?protocolHandler?->protocolHandler.setExecutor(Executors.newVirtualThreadPerTaskExecutor());?}

    這個 Bean 是一個自定義的 Tomcat 協議處理器,負責處理 Spring Boot 應用程序中傳入的請求。這個自定義程序的目的是配置協議處理器使用的執行器。

    在 threadExecutorCustomizer 方法內部,使用 Lambda 表達式來自定義協議處理器。protocolHandler 參數代表正在自定義的 Tomcat 協議處理器的實例。

    在 Lambda 表達式中,調用 protocolHandler 對象的 setExecutor() 方法,用于為協議處理器設置執行器。執行器負責執行任務,例如處理傳入的請求。

    在這種情況下,使用 Executors.newVirtualThreadPerTaskExecutor() 方法創建一個新的使用虛擬線程的執行器。虛擬線程是輕量級線程,可以在單個操作系統線程中并發執行任務。這意味著可以同時執行多個任務,提高性能和資源利用率。

    增加測試端點

    @Slf4j@RequestMapping@RestControllerpublic?class?DemoController?{????@GetMapping("/")????public?String?demo()?{????????try?{????????????TimeUnit.MILLISECONDS.sleep(300);????????}?catch?(InterruptedException?e)?{????????????log.error(e.getMessage());????????}????????return?"Current?Thread?Name:?"?+?Thread.currentThread();????}}

    上手使用

    我們可以通過 Thread.currentThread() API 獲取當前請求線程的元信息,以判斷虛擬線程是否已經正確開啟。

    性能測試對比100 線程測試不開啟虛擬線程
    吞吐量 300/s
    開啟虛擬線程
    吞吐量 300/s
    300 線程測試不開啟虛擬線程
    吞吐量 650/s
    開啟虛擬線程
    吞吐量 950/s
    500 線程測試不開啟虛擬線程
    吞吐量 650/s
    開啟虛擬線程
    吞吐量 1500/s
    圖表輸出總結

    通過以上我們發現,在處理阻塞操作時,虛擬線程特別有益。隨著并發請求數量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 Spring Boot 項目進行調優和優化的情況下進行的。

    參考資料[1]

    Azul Zulu 發行版 20.30.11 版本: https://www.azul.com/downloads/?version=java-20-sts&os=macos&architecture=arm-64-bit&package=jdk#zulu

    標簽:

    相關熱詞搜索:

    [責任編輯:]

    相關閱讀

    最近更新

    日日噜噜夜夜狠狠扒开双腿,欧美视频在线第一页,伦理草民看一天宅急看,超清国产粉嫩456在线免播放
    <bdo id="4awyc"><del id="4awyc"></del></bdo>
  • <s id="4awyc"></s>
  • <tfoot id="4awyc"><small id="4awyc"></small></tfoot>
    <s id="4awyc"><acronym id="4awyc"></acronym></s>
  • <center id="4awyc"></center>
    <s id="4awyc"><acronym id="4awyc"></acronym></s>
    主站蜘蛛池模板: 老师好紧开裆蕾丝内裤h男男 | 天堂网在线www| 女人被男人躁的女爽免费视频| 国产一区二区精品久久凹凸| 久久国产精品无码一区二区三区 | 小时代1免费观看完整版| 四虎国产精品高清在线观看| 中文字幕无码日韩欧毛| 色综合久久天天综合| 日本亚洲国产一区二区三区| 国产成人h片视频在线观看| 久久精品视频16| 99re热视频| 精品久久久久久久九九九精品 | 精品久久人妻av中文字幕| 希岛婚前侵犯中文字幕在线| 动漫触手被吸乳羞羞动漫| 久久综合久久网| 高清色本在线www| 欧美日韩国产成人高清视频| 国产综合在线观看| 免费又黄又爽1000禁片| caoporn97在线视频| 美女私密无遮挡网站视频| 怡红院免费手机在线观看| 免费在线观看污视频网站| 98精品国产综合久久| 欧美巨大黑人精品videos| 天使萌一区二区在线观看| 亚洲欧美一区二区成人片| 草草影院www色欧美极品| 波多野吉衣AV无码| 天天摸天天躁天天添天天爽| 午夜天堂在线观看| 99精品视频免费在线观看| 欧美第一页在线| 在线免费黄色网址| 亚洲国产成人91精品| 黄在线观看网站| 欧美人与zoxxxx视频| 国产精品沙发午睡系列999|