在以往的項(xiàng)目中,我們面臨了這樣一種情況:我們收到了數(shù)千個(gè)認(rèn)證請求。為了確保安全性,我們依靠第三方系統(tǒng)發(fā)送短信 OTP 進(jìn)行驗(yàn)證。然而,有時(shí)候第三方系統(tǒng)花費(fèi)的時(shí)間比預(yù)期的要長,導(dǎo)致延遲。我們采用了每個(gè)請求一個(gè)線程的模型,這意味著許多線程處于等待狀態(tài),并且新請求都在隊(duì)列中。我們試圖通過微調(diào)線程數(shù)量來優(yōu)化性能,但當(dāng)時(shí)我們希望有虛擬線程功能。當(dāng)時(shí) Java 中沒有虛擬線程的概念,這就是 Project Loom 的作用。
什么是 Project Loom?什么是 Project Loom?這是 Oracle 的一個(gè)新項(xiàng)目,主要目標(biāo)是顯著減少編寫、維護(hù)和觀察高吞吐量并發(fā)應(yīng)用程序的工作量。換句話說,Project Loom 旨在支持和推進(jìn)一個(gè)高吞吐量、輕量級(jí)的 Java 并發(fā)模型,因?yàn)閭鹘y(tǒng)的操作系統(tǒng)線程(Java 并發(fā)模型的核心)有一些缺點(diǎn),并且在計(jì)算上相當(dāng)昂貴。反之,虛擬線程是更輕量級(jí)的線程,不與操作系統(tǒng)線程連接(由 JVM 管理)。這意味著虛擬線程是“每請求對應(yīng)一個(gè)線程”編程的理想選擇,可以創(chuàng)建大量的虛擬線程,而不會(huì)降低吞吐量。開發(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]
(相關(guān)資料圖)
創(chuàng)建測試項(xiàng)目使用 Spring Initializer 或 IDE 創(chuàng)建項(xiàng)目。添加 spring-web 依賴項(xiàng)并添加元數(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());?}
這個(gè) Bean 是一個(gè)自定義的 Tomcat 協(xié)議處理器,負(fù)責(zé)處理 Spring Boot 應(yīng)用程序中傳入的請求。這個(gè)自定義程序的目的是配置協(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)建一個(gè)新的使用虛擬線程的執(zhí)行器。虛擬線程是輕量級(jí)線程,可以在單個(gè)操作系統(tǒng)線程中并發(fā)執(zhí)行任務(wù)。這意味著可以同時(shí)執(zhí)行多個(gè)任務(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 線程測試不開啟虛擬線程開啟虛擬線程300 線程測試不開啟虛擬線程開啟虛擬線程500 線程測試不開啟虛擬線程開啟虛擬線程圖表輸出總結(jié)通過以上我們發(fā)現(xiàn),在處理阻塞操作時(shí),虛擬線程特別有益。隨著并發(fā)請求數(shù)量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 Spring Boot 項(xiàng)目進(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)鍵詞:
凡注有"實(shí)況網(wǎng)-重新發(fā)現(xiàn)生活"或電頭為"實(shí)況網(wǎng)-重新發(fā)現(xiàn)生活"的稿件,均為實(shí)況網(wǎng)-重新發(fā)現(xiàn)生活獨(dú)家版權(quán)所有,未經(jīng)許可不得轉(zhuǎn)載或鏡像;授權(quán)轉(zhuǎn)載必須注明來源為"實(shí)況網(wǎng)-重新發(fā)現(xiàn)生活",并保留"實(shí)況網(wǎng)-重新發(fā)現(xiàn)生活"的電頭。
熱點(diǎn)
- 6月22日豬價(jià) | 節(jié)前散戶、大場出欄多,大豬不好賣了!
- 記者Vlog丨粽有風(fēng)情萬種 粽有家鄉(xiāng)味道
- 約戰(zhàn)平臺(tái)官網(wǎng)下載_o3o4o5約戰(zhàn)平臺(tái) 全球快播
- 時(shí)報(bào)觀察丨長短期政策搭配 合力推動(dòng)消費(fèi)提檔升級(jí)
- 司馬遷的《史記刺客列傳》五位刺客,最瀟灑的刺客是他?
- 文化消費(fèi)漸行漸暖 當(dāng)前消息
- 天天視點(diǎn)!【利率債新發(fā)公告】23附息國債13今日發(fā)布發(fā)行公告
- 獨(dú)行俠交易(獨(dú)行俠野狼)-環(huán)球快播報(bào)
- 每日速訊:劉晨琳_劉晨琳 上海
- 媒體人:青島海牛想讓阿蘭回國效力 目前尚在初始運(yùn)作階段
頭條
- 百事通!夏至前的田野
- 團(tuán)代表故事丨95后趙夢:青年要拜群眾為師,把群眾當(dāng)成親人
- 《秀我中國 | 新時(shí)代中國鄉(xiāng)村志(第四集):千年梯田 十年新生》
- 公益微視頻|珍惜糧食,你我有責(zé) 全球視點(diǎn)
- 夏至丨流光半夏 美好日長
- 護(hù)航高校畢業(yè)生就業(yè)路 畢業(yè)生對民營企業(yè)關(guān)注重視度不斷提升_今日最新
- 新動(dòng)態(tài):從“村BA”到“村超”,是賽事更是新路
- 前沿資訊!人間好時(shí)節(jié)丨夏至:夏日如約而至 與你悅享清涼
- 每日短訊:新華視點(diǎn)︱返鄉(xiāng)新青年 振興新力量
- 夏收夏種近尾聲 夏糧收購情況如何?記者實(shí)地探訪→_環(huán)球要聞