性能提升 200% !SpringBoot 虛擬線程來了
在以往的項目中,我們面臨了這樣一種情況:我們收到了數(shù)千個認證請求。為了確保安全性,我們依靠第三方系統(tǒng)發(fā)送短信 OTP 進行驗證。然而,有時候第三方系統(tǒng)花費的時間比預(yù)期的要長,導(dǎo)致延遲。我們采用了每個請求一個線程的模型,這意味著許多線程處于等待狀態(tài),并且新請求都在隊列中。我們試圖通過微調(diào)線程數(shù)量來優(yōu)化性能,但當(dāng)時我們希望有虛擬線程功能。當(dāng)時 Java 中沒有虛擬線程的概念,這就是 Project Loom 的作用。
(相關(guān)資料圖)
什么是 Project Loom?這是 Oracle 的一個新項目,主要目標(biāo)是顯著減少編寫、維護和觀察高吞吐量并發(fā)應(yīng)用程序的工作量。換句話說,Project Loom 旨在支持和推進一個高吞吐量、輕量級的 Java 并發(fā)模型,因為傳統(tǒng)的操作系統(tǒng)線程(Java 并發(fā)模型的核心)有一些缺點,并且在計算上相當(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)
開啟虛擬線程功能默認情況下, 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é)議處理器,負責(zé)處理 Spring Boot 應(yīng)用程序中傳入的請求。這個自定義程序的目的是配置協(xié)議處理器使用的執(zhí)行器。
在 threadExecutorCustomizer 方法內(nèi)部,使用 Lambda 表達式來自定義協(xié)議處理器。protocolHandler 參數(shù)代表正在自定義的 Tomcat 協(xié)議處理器的實例。
在 Lambda 表達式中,調(diào)用 protocolHandler 對象的 setExecutor() 方法,用于為協(xié)議處理器設(shè)置執(zhí)行器。執(zhí)行器負責(zé)執(zhí)行任務(wù),例如處理傳入的請求。
在這種情況下,使用 Executors.newVirtualThreadPerTaskExecutor() 方法創(chuàng)建一個新的使用虛擬線程的執(zhí)行器。虛擬線程是輕量級線程,可以在單個操作系統(tǒng)線程中并發(fā)執(zhí)行任務(wù)。這意味著可以同時執(zhí)行多個任務(wù),提高性能和資源利用率。
增加測試端點@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 項目進行調(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)鍵詞:
相關(guān)閱讀
-
性能提升 200% !SpringBoot 虛擬線程來了
在以往的項目中,我們面臨了這樣一種情況:我們收到了數(shù)千個認證請求。 -
盤點二季度重卡新車,重卡平臺化迎來第...
隨著車企對降本增效重視程度的提升,平臺化、模塊化研發(fā)和生產(chǎn)幾乎成為 -
官方指導(dǎo)價8.99-12.79萬元 江淮釔為3正式上市
6月16日,江淮釔為官方正式公布了旗下純電動小型車——釔為3的最終... -
世界焦點!新房、二手房“五連漲”三亞...
每經(jīng)記者黃婉銀三亞樓市又熱了?今年1月以來,三亞新房、二手房住宅銷 -
當(dāng)前動態(tài):廣工男籃獲授予廣東青年五四獎?wù)?/a>
南都訊記者葉孜文通訊員岳青6月21日,共青團廣東省委員會、廣東省青年 -
天天熱點評!這些路段受大到暴雨影響!...
6月22日,交通運輸部發(fā)布全國公路氣象預(yù)報(6月22日20時至23日20時)。 -
可讓重卡快速制動的防撞預(yù)警系統(tǒng)亮相長春
6月20日,第五屆東北亞(吉林)安全應(yīng)急產(chǎn)業(yè)博覽會正在長春舉行,一參展 -
中考結(jié)束啦!華附考點考生:最想跑全馬...
一位媽媽將手中的向日葵遞給兒子,并囑咐道:“等哥哥出考場后你送... -
龍卷風(fēng)等惡劣天氣襲擊美國得州 造成至...
中新社舊金山6月22日電據(jù)美國媒體當(dāng)?shù)貢r間22日報道,21日晚,美國得克 -
全球快看點丨亞馬遜對review做出重大調(diào)整!
一直以來,review一直是跨境賣家的老大難問題。主要原因就是,平臺基本 -
當(dāng)前快播:八字命理:男命七殺格婚姻好...
他們能為朋友兩肋插刀,兄弟情意有說不出來的狂熱,在有需要的時候,大 -
里根號南海游蕩,解放軍出動5艘軍艦“包...
針對這種情況,我們的軍艦采取了包圍“里根”號航母并進行長時間監(jiān)... -
每日速看!拒絕頂薪,再見火箭!熱臉貼上...
拒絕頂薪,再見火箭!熱臉貼上冷屁股,承認吧,你離開后很失敗,哈登,火 -
618知乎用戶消費洞察報告:數(shù)碼內(nèi)容最受...
6月21日消息,近日,知乎發(fā)布了《2023年618知乎用戶消費洞察報告》,報 -
微軟宣布支持普通話|環(huán)球看點
微軟宣布桌面端用戶現(xiàn)在可以使用語音輸入的方式進行必應(yīng)聊天(BingChat -
海北海晏:錨定“四地”建設(shè)繪就河清海晏
(楊斌馬福全李雋)近年來,海北州海晏縣以獨特的文化底蘊與人文內(nèi)涵享有 -
當(dāng)前速看:Proenza Schouler 2024 早春系列發(fā)布
ProenzaSchoulerProenzaSchoulerProenzaSchoulerProenzaSchouler西裝剪 -
環(huán)球關(guān)注:寶武澳大利亞西坡項目開業(yè)
寶武澳大利亞西坡項目開業(yè):設(shè)計年產(chǎn)2500萬噸鐵礦石后年投產(chǎn)金十?dāng)?shù)據(jù)6 -
世界新消息丨臥龍區(qū)光武街道榆樹莊社區(qū)...
全媒體記者陳向革通訊員張桂英濃情端午,粽葉飄香,又是一年端午到。為 -
里見光鉆的黑執(zhí)事想當(dāng)優(yōu)秀素質(zhì)的訓(xùn)練員...
在和池江陸美敲定了集訓(xùn)計劃后,我久違地撥通海灘管理員的電話,向他說