性能提升 200% !SpringBoot 虛擬線程來了
在以往的項目中,我們面臨了這樣一種情況:我們收到了數(shù)千個認證請求。為了確保安全性,我們依靠第三方系統(tǒng)發(fā)送短信 OTP 進行驗證。然而,有時候第三方系統(tǒng)花費的時間比預期的要長,導致延遲。我們采用了每個請求一個線程的模型,這意味著許多線程處于等待狀態(tài),并且新請求都在隊列中。我們試圖通過微調線程數(shù)量來優(yōu)化性能,但當時我們希望有虛擬線程功能。當時 Java 中沒有虛擬線程的概念,這就是 Project Loom 的作用。
什么是 Project Loom?這是 Oracle 的一個新項目,主要目標是顯著減少編寫、維護和觀察高吞吐量并發(fā)應用程序的工作量。換句話說,Project Loom 旨在支持和推進一個高吞吐量、輕量級的 Java 并發(fā)模型,因為傳統(tǒng)的操作系統(tǒng)線程(Java 并發(fā)模型的核心)有一些缺點,并且在計算上相當昂貴。反之,虛擬線程是更輕量級的線程,不與操作系統(tǒng)線程連接(由 JVM 管理)。這意味著虛擬線程是“每請求對應一個線程”編程的理想選擇,可以創(chuàng)建大量的虛擬線程,而不會降低吞吐量。開發(fā)人員可以使用現(xiàn)有的 JDK 工具和技術快速排除故障、調試和分析并發(fā)應用程序,在發(fā)布的 Spring Boot 3.1 中可用。作為 Spring 開發(fā)者,了解虛擬線程的概念并理解它們在開發(fā)過程中的重要性非常關鍵。
(資料圖片僅供參考)
Java 19 中引入的虛擬線程非常易于使用,筆者使用的 Mac M1 系列,這里選擇 Azul Zulu 發(fā)行版 20.30.11 版本[1]
使用 Spring Initializer 或 IDE 創(chuàng)建項目。添加 spring-web 依賴項并添加元數(shù)據(jù)。(注意版本選擇 SpringBoot 3.1 ,Java 20)
開啟虛擬線程功能默認情況下, Java19 的虛擬線程功能是禁用狀態(tài)的,需要通過相關 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 協(xié)議處理器,負責處理 Spring Boot 應用程序中傳入的請求。這個自定義程序的目的是配置協(xié)議處理器使用的執(zhí)行器。
在 threadExecutorCustomizer 方法內部,使用 Lambda 表達式來自定義協(xié)議處理器。protocolHandler 參數(shù)代表正在自定義的 Tomcat 協(xié)議處理器的實例。
在 Lambda 表達式中,調用 protocolHandler 對象的 setExecutor() 方法,用于為協(xié)議處理器設置執(zhí)行器。執(zhí)行器負責執(zhí)行任務,例如處理傳入的請求。
在這種情況下,使用 Executors.newVirtualThreadPerTaskExecutor() 方法創(chuàng)建一個新的使用虛擬線程的執(zhí)行器。虛擬線程是輕量級線程,可以在單個操作系統(tǒng)線程中并發(fā)執(zhí)行任務。這意味著可以同時執(zhí)行多個任務,提高性能和資源利用率。
增加測試端點@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 線程測試不開啟虛擬線程通過以上我們發(fā)現(xiàn),在處理阻塞操作時,虛擬線程特別有益。隨著并發(fā)請求數(shù)量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 Spring Boot 項目進行調優(yōu)和優(yōu)化的情況下進行的。
參考資料[1]Azul Zulu 發(fā)行版 20.30.11 版本: https://www.azul.com/downloads/?version=java-20-sts&os=macos&architecture=arm-64-bit&package=jdk#zulu
關鍵詞:
您可能也感興趣:
今日熱點
為您推薦
今日播報!5年期LPR為何只降10個基點?
百事通!銅箔排名前十名:上市公司凈利率前10榜單(第一季度)
剛喝完它,小伙就進了搶救室!很多年輕人都在買-微速訊
排行
最近更新
- 性能提升 200% !SpringBoot 虛擬線程來了
- 狐廠大拷問 | 朱一龍:沒規(guī)劃過轉型,獲得認可后更自信松弛
- 高溫黃色預警!最高氣溫可達38℃,預計高溫緩解時間為……
- 氣象專家解讀北方高溫天氣_當前頭條
- 世界快消息!蔬菜、水果主要向人們提供什么營養(yǎng)?
- 夏天小孩吃什么水果好?_當前熱議
- 聚焦幼兒“三性” 創(chuàng)設互動環(huán)境|天天觀天下
- 魚肝油有什么功效? 全球熱推薦
- 推土機復盤劇本殺《黑旗》復盤解析+誰是兇手+真相答案+手法動...
- 2023廣鐵集團招聘畢業(yè)生177人報名流程一覽(附報名入口)
- 陶慧敏經紀公司
- 【環(huán)球報資訊】成都中醫(yī)腫瘤研究院趙春天:年輕人出現(xiàn)哪些癥...
- 高質量發(fā)展調研行丨“福海糧倉”生機勃勃|環(huán)球熱訊
- 世界快消息!端午假日 樂游無錫
- 浙江臨?!白畹驼{”的國家級文物,免費開放,但很多游客不知道
- 市財政局:聚焦三項重點優(yōu)化財稅營商環(huán)境
- 2023年甘肅高考成績今日公布 世界新視野
- 2023-2028年車用氣凝膠行業(yè)市場深度調研及投資前景預測分析報...
- PS掌機售價低于300美元:或于今年11月發(fā)售?。黀S5今年兩款獨...
- 焦點熱門:IMF俄羅斯執(zhí)行董事:美國一手造成全球“去美元化”
- 十二星座,這就是你失眠的原因!每晚都在胡思亂想,難以入眠_...
- 基于EMP2 V3平臺/采用全新設計 全新DS 4將于7月13日正式上市-全球熱議
- 【駕春秋】2025款大眾探歌諜照曝光 將是最后一代燃油版 環(huán)球最資訊
- 環(huán)球快訊:河北200萬臺農機收麥忙
- 注意啦!披著飲料"外衣" 這種含毒"上頭潮飲"不能碰|微頭條
- 廣西賀州:構建“一石多吃”新業(yè)態(tài)
- 老刀:如何看普里戈任將流亡白俄羅斯,瓦格納叛軍已返回營地...
- IBM擬至多50億美元收購軟件公司Apptio,或于本周末達成協(xié)議 ...
- 蘇提達連續(xù)三次現(xiàn)身,全新造型靚麗又減齡,曾穿時裝款也知性漂亮
- 快播:拯救地球首發(fā)怎么排?迪克:魔術師&科比&詹姆斯&奧尼爾...