熱點(diǎn)聚焦:性能提升 200% !SpringBoot 虛擬線程來了
時間:2023-06-24 23:48:38
在以往的項目中,我們面臨了這樣一種情況:我們收到了數(shù)千個認(rèn)證請求。為了確保安全性,我們依靠第三方系統(tǒng)發(fā)送短信 OTP 進(jìn)行驗證。然而,有時候第三方系統(tǒng)花費(fèi)的時間比預(yù)期的要長,導(dǎo)致延遲。我們采用了每個請求一個線程的模型,這意味著許多線程處于等待狀態(tài),并且新請求都在隊列中。我們試圖通過微調(diào)線程數(shù)量來優(yōu)化性能,但當(dāng)時我們希望有虛擬線程功能。當(dāng)時 Java 中沒有虛擬線程的概念,這就是 Project Loom 的作用。
【資料圖】
什么是 Project Loom?這是 Oracle 的一個新項目,主要目標(biāo)是顯著減少編寫、維護(hù)和觀察高吞吐量并發(fā)應(yīng)用程序的工作量。換句話說,Project Loom 旨在支持和推進(jìn)一個高吞吐量、輕量級的 Java 并發(fā)模型,因為傳統(tǒng)的操作系統(tǒng)線程(Java 并發(fā)模型的核心)有一些缺點(diǎn),并且在計算上相當(dāng)昂貴。反之,虛擬線程是更輕量級的線程,不與操作系統(tǒng)線程連接(由 JVM 管理)。這意味著虛擬線程是“每請求對應(yīng)一個線程”編程的理想選擇,可以創(chuàng)建大量的虛擬線程,而不會降低吞吐量。開發(fā)人員可以使用現(xiàn)有的 JDK 工具和技術(shù)快速排除故障、調(diào)試和分析并發(fā)應(yīng)用程序,在發(fā)布的 Spring Boot 3.1 中可用。作為 Spring 開發(fā)者,了解虛擬線程的概念并理解它們在開發(fā)過程中的重要性非常關(guān)鍵。
如何使用虛擬線程Java 版本選擇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)
開啟虛擬線程功能默認(rèn)情況下, 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é)議處理器,負(fù)責(zé)處理 Spring Boot 應(yīng)用程序中傳入的請求。這個自定義程序的目的是配置協(xié)議處理器使用的執(zhí)行器。
在 threadExecutorCustomizer 方法內(nèi)部,使用 Lambda 表達(dá)式來自定義協(xié)議處理器。protocolHandler 參數(shù)代表正在自定義的 Tomcat 協(xié)議處理器的實(shí)例。
在 Lambda 表達(dá)式中,調(diào)用 protocolHandler 對象的 setExecutor() 方法,用于為協(xié)議處理器設(shè)置執(zhí)行器。執(zhí)行器負(fù)責(zé)執(zhí)行任務(wù),例如處理傳入的請求。
在這種情況下,使用 Executors.newVirtualThreadPerTaskExecutor() 方法創(chuàng)建一個新的使用虛擬線程的執(zhí)行器。虛擬線程是輕量級線程,可以在單個操作系統(tǒng)線程中并發(fā)執(zhí)行任務(wù)。這意味著可以同時執(zhí)行多個任務(wù),提高性能和資源利用率。
增加測試端點(diǎn)@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 獲取當(dāng)前請求線程的元信息,以判斷虛擬線程是否已經(jīng)正確開啟。
性能測試對比100 線程測試不開啟虛擬線程通過以上我們發(fā)現(xiàn),在處理阻塞操作時,虛擬線程特別有益。隨著并發(fā)請求數(shù)量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 Spring Boot 項目進(jìn)行調(diào)優(yōu)和優(yōu)化的情況下進(jìn)行的。
參考資料[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)稿件
熱點(diǎn)聚焦:性能提升 200% !SpringBoot 虛擬線程來了
白玉蘭獎看點(diǎn)多,女星紅毯千姿百態(tài),吳越拿下大獎,趙麗穎有些可惜
把“空間站”建在地球上——走進(jìn)我國航天領(lǐng)域首個大科學(xué)裝置
端午節(jié)假期出游人次破億 文旅產(chǎn)品服務(wù)豐富-全球快資訊
廈門地鐵6號線角美延伸段角社盾構(gòu)區(qū)間實(shí)現(xiàn)雙線貫通
美失事潛艇5名富豪或0.03秒內(nèi)死亡 到底是怎么回事? 新動態(tài)
這里,成了端午節(jié)最靚的景點(diǎn)! 世界即時
足協(xié)杯-平科破門呂文君李圣龍建功 上海海港3-1勝廣州晉級-每日速遞
如何辨認(rèn)婚禮儀式上已故親人,探討老公生日應(yīng)該送什么禮物? 世界速讀
新動態(tài):照片太大了怎么改小kb ?怎么將圖片kb壓縮變小
環(huán)球觀天下!俄媒:俄南部軍區(qū)位于羅斯托夫總部大樓已被“瓦格納”包圍
天天要聞:未來兩周,運(yùn)勢大旺,桃花上門,邂逅愛情,真愛相伴,甜蜜相隨
皮膚不好吃什么維生素(皮膚不好吃維生素E好還是維生素C好)|全球播報
過度喂養(yǎng)是傷害!判斷孩子是否吃飽,看這些信號就夠了
“瓦格納”稱占領(lǐng)俄南部軍區(qū)指揮部_聚看點(diǎn)
2023河南美術(shù)生本科分?jǐn)?shù)線多少分(含2021-2022年) 全球微速訊
教育頻道
廈門地鐵6號線角美延伸段角社盾構(gòu)區(qū)間實(shí)現(xiàn)雙線貫通
每日精選:2023?3D動畫電影《蘑菇精靈》動漫設(shè)計全國大賽啟動
撿兩張angelababy的照片 angelababy真的可以駕馭各種風(fēng)格啊!_全球熱推薦
廈門湖里醫(yī)保交多少年才能醫(yī)保退休,廈門湖里醫(yī)保繳費(fèi)年限如何法規(guī)
焦點(diǎn)短訊!川觀拍客共同觀看電影《消失的她》大贊“國產(chǎn)懸疑天花板”
天天視訊!身上滿滿負(fù)能量的星座排行榜,雙子簡直負(fù)能量爆棚!
香港機(jī)場一客機(jī)中止起飛 機(jī)上乘客被緊急疏散|當(dāng)前播報


