天天看熱訊:性能提升 200% !SpringBoot 虛擬線程來了
在以往的項目中,我們面臨了這樣一種情況:我們收到了數千個認證請求。為了確保安全性,我們依靠第三方系統發送短信 OTP 進行驗證。然而,有時候第三方系統花費的時間比預期的要長,導致延遲。我們采用了每個請求一個線程的模型,這意味著許多線程處于等待狀態,并且新請求都在隊列中。我們試圖通過微調線程數量來優化性能,但當時我們希望有虛擬線程功能。當時 Java 中沒有虛擬線程的概念,這就是 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 線程測試不開啟虛擬線程通過以上我們發現,在處理阻塞操作時,虛擬線程特別有益。隨著并發請求數量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 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
關鍵詞:
相關閱讀
-
天天看熱訊:性能提升 200% !SpringB...
在以往的項目中,我們面臨了這樣一種情況:我們收到了數千個認證請求。 -
為什么同樣交易方法有人虧損,有人盈利...
交易策略本質是交易勝率、交易賠率和交易效率的有序組合。我們經常講交 -
貴州“村超”的“超級周末” 每日時訊
貴州“村超”的“超級周末” -
實時焦點:莫斯科等地實行反恐行動制度...
【莫斯科等地實行反恐行動制度俄對瓦格納組織創始人刑事立案】俄羅斯國 -
網傳我國轟-6k低空突防美國航母,原來真...
網傳我國轟-6k低空突防美國航母近日,一貫在全球耀武揚威的美國航母艦 -
天天最資訊丨當前聚焦:山水相融,風景...
(相關資料圖)延慶東南部,山水相融,風景如畫。今年至2025年,這里將建 -
普京:向那些“受欺騙和威脅而走上武裝...
本文轉自【CCTV國際時訊】;最新消息:俄羅斯總統普京開始講話。普京表 -
環球快訊:門源縣氣象臺發布黃色雷電預警
【來源:門源回族自治縣氣象局】門源回族自治縣氣象臺6月23日18時40分 -
1.06億人次出游!今年端午節假期國內旅...
2023年端午節假期,文化和旅游行業復蘇勢頭強勁,全國假日市場總體安全 -
當前關注:葛洲壩集團承建的中東歐最大...
【葛洲壩集團承建的中東歐最大水電站項目開工】中國能建葛洲壩集團承建 -
世界熱點評!第十九屆中國國際動漫節閉...
6月24日,第十九屆中國國際動漫節在浙江杭州閉幕。本屆動漫節集聚了120 -
【全球時快訊】你不知道的真相是,雞娃...
這才是“雞娃”的正確打開方式 -
關于開展2024年省級促進經濟高質量發展...
各園區、鎮(街)工業和信息化主管部門,有關企業:根據《廣東省工業和信 -
Meta首席科學家:AI不如狗聰明-每日速讀
AI前線編譯|Sambodhi、凌敏毫無疑問,當前的AI仍存在一定的局限性。AI -
復讀女生漲61分坐地嚎啕大哭 基本信息...
大家好,今日關于【復讀女生漲61分坐地嚎啕大哭】的話題登上了各大平臺 -
2023年陜西高考錄取分數線公布
經省招生委員會研究決定,2023年全國普通高等學校招生陜西省各批次錄取 -
首屆北京中華民族文化周閉幕
首屆北京中華民族文化周聚焦“美美與共、籽籽同心”主題,既是一場... -
天天觀察:太原鐵路增開30趟旅客列車應...
6月24日,隨著端午假期臨近尾聲,中國鐵路太原局集團有限公司管內迎 -
車速太快遇彎道輪胎打滑,面包車沖破護...
揚子晚報網6月24日訊(通訊員楊昌平記者梅建明)近日,南京江寧開發區 -
世界熱訊:手臂骨折手術后大拇指食指翹不...
手臂骨折手術后大拇指食指翹不起來?反應過醫院說正常?一個月拆
