性能提升 200% !SpringBoot 虛擬線程來了|環(huán)球滾動
在以往的項目中,我們面臨了這樣一種情況:我們收到了數(shù)千個認證請求。為了確保安全性,我們依靠第三方系統(tǒng)發(fā)送短信 OTP 進行驗證。然而,有時候第三方系統(tǒng)花費的時間比預期的要長,導致延遲。我們采用了每個請求一個線程的模型,這意味著許多線程處于等待狀態(tài),并且新請求都在隊列中。我們試圖通過微調(diào)線程數(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 工具和技術(shù)快速排除故障、調(diào)試和分析并發(fā)應用程序,在發(fā)布的 Spring Boot 3.1 中可用。作為 Spring 開發(fā)者,了解虛擬線程的概念并理解它們在開發(fā)過程中的重要性非常關(guān)鍵。
如何使用虛擬線程Java 版本選擇Java 19 中引入的虛擬線程非常易于使用,筆者使用的 Mac M1 系列,這里選擇 Azul Zulu 發(fā)行版 20.30.11 版本[1]
(相關(guān)資料圖)
使用 Spring Initializer 或 IDE 創(chuàng)建項目。添加 spring-web 依賴項并添加元數(shù)據(jù)。(注意版本選擇 SpringBoot 3.1 ,Java 20)
開啟虛擬線程功能默認情況下, Java19 的虛擬線程功能是禁用狀態(tài)的,需要通過相關(guān) 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 方法內(nèi)部,使用 Lambda 表達式來自定義協(xié)議處理器。protocolHandler 參數(shù)代表正在自定義的 Tomcat 協(xié)議處理器的實例。
在 Lambda 表達式中,調(diào)用 protocolHandler 對象的 setExecutor() 方法,用于為協(xié)議處理器設(shè)置執(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 獲取當前請求線程的元信息,以判斷虛擬線程是否已經(jīng)正確開啟。
性能測試對比100 線程測試不開啟虛擬線程通過以上我們發(fā)現(xiàn),在處理阻塞操作時,虛擬線程特別有益。隨著并發(fā)請求數(shù)量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 Spring Boot 項目進行調(diào)優(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
關(guān)鍵詞:
您可能也感興趣:
為您推薦
2021揭陽榕城區(qū)東興+東升+東陽三個派出所設(shè)置戶籍室
贛南醫(yī)學院、九江學院主要負責同志調(diào)整|環(huán)球快報
古語中張良計指的是什么意思_古語中張良計指的是什么
排行
最近更新
- 性能提升 200% !SpringBoot 虛擬線程來了|環(huán)球滾動
- 《神奇101重制版》DLC可單獨購買體驗無需本體
- 亞太經(jīng)合組織助力數(shù)字化綠色化協(xié)同轉(zhuǎn)型發(fā)展
- 美好的周末,又改了一天 Bug。。 今日報
- 微頭條丨94歲老戰(zhàn)士獲終身成就獎!他的作品太震撼
- 【全球播資訊】瘋狂污染互聯(lián)網(wǎng),人類比 AI 擅長多了
- 全球即時看!遼寧營口一鋼鐵廠發(fā)生燙傷事故 造成4人死亡5人受傷
- 太牛了!中國射擊隊女子奪冠成績比男子還高,網(wǎng)友直呼被刷新認知
- 天天速讀:四川3所高校換帥
- 趕走馬隊又賣托納利!這還是你熟悉的米蘭嗎?
- 天天熱議:【痛風能吃馬齒莧嗎】?
- 市盈率等于凈利潤增長率_市盈率除以每股收益增長率
- 也門西南部遭暴雨襲擊 已致12人死亡8人失蹤-天天即時看
- 觀熱點:武漢少年警隊:防溺水課堂開講
- 高盛:予騰訊控股(00700)“買入”評級 目標價443港元
- 小摩:下調(diào)香港寬頻評級至“減持” 目標價3.7港元 環(huán)球快播報
- 環(huán)球關(guān)注:第三批“山東省高校黃大年式教師團隊”評選結(jié)果公示
- 世界最大尺寸安全殼模型熱壓耦合試驗圓滿完成 今日聚焦
- 淮安淮陰區(qū)星級養(yǎng)老院名單
- 正式官宣!山東男籃熱身賽出爐,丁偉PK萊登楊鳴,與遼籃激戰(zhàn)4場
- 創(chuàng)新電商模式意義重大-快看
- 小卡接受手術(shù)需8周康復!快船總裁繼續(xù)圍繞卡椒建隊:盼威少回...
- 焦點熱訊:誰還有夢想?選秀大會后 熱火火速簽下五名落選秀
- 2023年6月23日十二星座運勢快送|今日要聞
- 今后2年,四大生肖好運煥發(fā),生活順心如意,波瀾不驚邂逅真愛
- 坂本龍一最后的告白:渴望創(chuàng)作新的樂章,直至生命燃盡 環(huán)球關(guān)注
- 糧市風向變,新炒作醞釀。_天天新視野
- 又見國之重器!重近3.5萬噸,20多次刷新紀錄,作業(yè)高度相當于...
- 天天時訊:端午話“粽”
- 天天觀天下!湖北襄陽:漢江河畔賽龍舟 奮楫擊水慶端午