性能提升 200% !SpringBoot 虛擬線程來了
在以往的項目中,我們面臨了這樣一種情況:我們收到了數千個認證請求。為了確保安全性,我們依靠第三方系統發送短信 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]
創建測試項目使用 Spring Initializer 或 IDE 創建項目。添加 spring-web 依賴項并添加元數據。(注意版本選擇 SpringBoot 3.1 ,Java 20)
開啟虛擬線程功能默認情況下, Java19 的虛擬線程功能是禁用狀態的,需要通過相關 maven 編譯配置開啟。
通過配置 bean 啟用虛擬線程org.springframework.boot spring-boot-maven-plugin org.apache.maven.plugins maven-compiler-plugin --enable-preview
@Bean?TomcatProtocolHandlerCustomizer>threadExecutorCustomizer()?{??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 線程測試不開啟虛擬線程開啟虛擬線程500 線程測試不開啟虛擬線程開啟虛擬線程圖表輸出總結通過以上我們發現,在處理阻塞操作時,虛擬線程特別有益。隨著并發請求數量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 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
關鍵詞:
您可能也感興趣:
為您推薦
一心堂開店提速:新投近6000萬并購 曾稱今年將拓展門店近2000家
今日關注:安平縣氣象臺更新高溫紅色預警[Ⅰ級/特別嚴重] 【2023-06-22】
世界今熱點:睡眠呼吸暫停綜合征能治愈嗎 呼吸驟停會怎么樣
排行
最近更新
- 性能提升 200% !SpringBoot 虛擬線程來了
- 應急管理部派工作組赴事故現場指導救援處置-當前頭條
- 小鵬的掉隊危機何解?
- 繪制新銳青年群像 全球視訊
- 游戲神器12490F史低價1149元
- 惠普戰66五代筆記本促銷活動熱力再燃
- 世界熱文:(“千萬工程”調研行)這座千年古村里有了天文館...
- 蘿卜小咸菜的家常做法?-環球熱點
- 當前訊息:祥鵬航空新推昆明=呼和浩特“暢游”航線
- 同心四川祝大家端午安康!-全球觀熱點
- 2023北京數字經濟體驗周暨數字消費節開幕 焦點速讀
- 首屆北京中華民族文化周開幕 注重文化可參與可觀賞可體驗 ...
- 圖片報:哈維-阿隆索是弗洛倫蒂諾心中接替安帥的首選 當前關注
- 巴南:非遺民俗迎端午 幸福鄰里一家親
- 全美熱搜第一!熱議三方交易:蘇群看好綠軍前景 綠軍記者全不滿
- 全球熱門:生意不好怎么轉運?收藏
- 以調促審解“薪”愁 法護營商新“楓”景
- 世界動態:剛剛,武漢2023年中考試卷及參考答案來了!
- 今日聚焦!克拉瑪依市舉辦禁毒公益彩虹跑活動
- 杭州亞運會和亞殘運會物流中心啟用-世界最新
- 廣西武警文化輕騎兵進基層巡演
- 總投資75.9億元 宜良招商引資推介會簽約項目16個-世界微速訊
- 洞察2023:中國再生醫學行業競爭格局及市場份額
- 膽囊切除了對身體有什么影響(切除膽囊對身體有什么影響嗎?)_...
- 熬過18天,四大生肖吉星拱照,收入翻倍漲,情定終身
- 全球快看點丨明年俄羅斯天然氣或停止過境烏克蘭
- 中國科學家當選ISCB Fellow
- 天天視點!團代表故事丨海霞女民兵曾秀紅:接過老一輩的鋼槍...
- 河北遷安:白果樹下粽飄香 鄉村文化有傳承
- 九吉公紅糖多少錢一盒呀_九吉公紅糖多少錢一盒_關注