国产美女主播视频一区_国产精品蜜臀在线观看_亚洲成人动漫一区_亚洲视屏在线播放

首頁 > 培訓

性能提升 200% !SpringBoot 虛擬線程來了

來源:程序員客棧 時間:2023-06-24 09:43:18

在以往的項目中,我們面臨了這樣一種情況:我們收到了數千個認證請求。為了確保安全性,我們依靠第三方系統發送短信 OTP 進行驗證。然而,有時候第三方系統花費的時間比預期的要長,導致延遲。我們采用了每個請求一個線程的模型,這意味著許多線程處于等待狀態,并且新請求都在隊列中。我們試圖通過微調線程數量來優化性能,但當時我們希望有虛擬線程功能。當時 Java 中沒有虛擬線程的概念,這就是 Project Loom 的作用。

虛擬線程
什么是 Project Loom?

什么是 Project Loom?這是 Oracle 的一個新項目,主要目標是顯著減少編寫、維護和觀察高吞吐量并發應用程序的工作量。換句話說,Project Loom 旨在支持和推進一個高吞吐量、輕量級的 Java 并發模型,因為傳統的操作系統線程(Java 并發模型的核心)有一些缺點,并且在計算上相當昂貴。反之,虛擬線程是更輕量級的線程,不與操作系統線程連接(由 JVM 管理)。這意味著虛擬線程是“每請求對應一個線程”編程的理想選擇,可以創建大量的虛擬線程,而不會降低吞吐量。開發人員可以使用現有的 JDK 工具和技術快速排除故障、調試和分析并發應用程序,在發布的 Spring Boot 3.1 中可用。作為 Spring 開發者,了解虛擬線程的概念并理解它們在開發過程中的重要性非常關鍵。


【資料圖】

如何使用虛擬線程Java 版本選擇

Java 19 中引入的虛擬線程非常易于使用,筆者使用的 Mac M1 系列,這里選擇 Azul Zulu 發行版 20.30.11 版本[1]

azul 20
創建測試項目

使用 Spring Initializer 或 IDE 創建項目。添加 spring-web 依賴項并添加元數據。(注意版本選擇 SpringBoot 3.1 ,Java 20)

開啟虛擬線程功能
默認報錯

默認情況下, Java19 的虛擬線程功能是禁用狀態的,需要通過相關 maven 編譯配置開啟。

org.springframework.bootspring-boot-maven-pluginorg.apache.maven.pluginsmaven-compiler-plugin--enable-preview

通過配置 bean 啟用虛擬線程

@Bean?TomcatProtocolHandlerCustomizerthreadExecutorCustomizer()?{??return?protocolHandler?->protocolHandler.setExecutor(Executors.newVirtualThreadPerTaskExecutor());?}

這個 Bean 是一個自定義的 Tomcat 協議處理器,負責處理 Spring Boot 應用程序中傳入的請求。這個自定義程序的目的是配置協議處理器使用的執行器。

在 threadExecutorCustomizer 方法內部,使用 Lambda 表達式來自定義協議處理器。protocolHandler 參數代表正在自定義的 Tomcat 協議處理器的實例。

在 Lambda 表達式中,調用 protocolHandler 對象的 setExecutor() 方法,用于為協議處理器設置執行器。執行器負責執行任務,例如處理傳入的請求。

在這種情況下,使用 Executors.newVirtualThreadPerTaskExecutor() 方法創建一個新的使用虛擬線程的執行器。虛擬線程是輕量級線程,可以在單個操作系統線程中并發執行任務。這意味著可以同時執行多個任務,提高性能和資源利用率。

增加測試端點

@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 線程測試不開啟虛擬線程
吞吐量 300/s
開啟虛擬線程
吞吐量 300/s
300 線程測試不開啟虛擬線程
吞吐量 650/s
開啟虛擬線程
吞吐量 950/s
500 線程測試不開啟虛擬線程
吞吐量 650/s
開啟虛擬線程
吞吐量 1500/s
圖表輸出總結

通過以上我們發現,在處理阻塞操作時,虛擬線程特別有益。隨著并發請求數量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 Spring Boot 項目進行調優和優化的情況下進行的。

參考資料[1]

Azul Zulu 發行版 20.30.11 版本: https://www.azul.com/downloads/?version=java-20-sts&os=macos&architecture=arm-64-bit&package=jdk#zulu

相關稿件

性能提升 200% !SpringBoot 虛擬線程來了

我國最長深水油氣管道進入調試階段

在“AI概念股”甲骨文公司股價創下歷史新高后,拉里·埃里森本周行使了即將到期的期權并出售了6.4億美元的股票-焦點快看

青海選手仁青東知布 貴州選手楊花分獲男女全馬冠軍 今日報

俄羅斯首都莫斯科已加強安全措施

環球微動態丨我市推進專項行動 強化河湖水域岸線保護

@陜西高考生,今天中午12點起,開始填志愿!-焦點

l1是什么線(L1,L2,L3代表什么線)

拓詞方法提升效率10倍 每日熱文

紅米K60Ultra配天璣發布|天天滾動

第十三屆“喀交會”簽約61個項目 總額達524.83億元

報道:什么是止盈止損 什么是止盈止損價格

全球訊息:40歲左右的女人,夏天都愛穿半身裙,3種搭配方式,舒適提氣質

端午假期戰一線 高鐵建設不停歇

也門遭暴雨襲擊 已致12人死亡8人失蹤

蘋果iOS 16.5.1正式版發布 建議升級!

眼鏡店開業祝賀詞 世界新動態

下周115股面臨解禁 合計解禁市值超千億

安全海南丨海南多地對瓶裝液化石油氣、燃氣等開展安全專項排查整治

環球熱資訊!細節曝光:繳獲可卡因1噸!廣東警方偵破特大海上跨國走私毒品案

白玉蘭獎揭曉,《人世間》成最大贏家!最佳男女主角是他們

【全球新要聞】突發!國泰航空一客機突發故障,11人逃生途中受傷送醫!女乘客還原驚恐一幕:有人打電話給父母一直哭,有一個媽媽抱著孩子一直說對不起……

環球焦點!小六壬運勢分析:揭秘未來命運的神秘法術

環球今頭條!未來10天,四大生肖有貴人指點,好運連連,愛情事業有驚喜

全球最資訊丨每日訊息!值得推薦的十部愛情電影 五部讓你臉紅心跳的愛情電影-最新消息 消息

推動品牌建設上臺階

亮馬河藝術之夜系列微演出啟動 濱水夜生活增添“煙火氣”

大樂透23071期金銀膽碼推薦

【世界播資訊】“國會山股神”佩洛西出手 行權買入蘋果(AAPL.US)、微軟(MSFT.US)股票

世界觀察:我國最長深水油氣管道進入調試階段


主站蜘蛛池模板: 日韩欧美亚洲天堂| 日韩欧美亚洲天堂| 久久久久久国产精品久久| 国模吧无码一区二区三区| 俄罗斯精品一区二区| 久久天天狠狠| 日韩欧美亚洲v片| 91av在线不卡| 亚洲日本精品国产第一区| 丰满少妇久久久| 国产精品久久久影院| 久久精品一区二区三区不卡免费视频| 日韩精品极品视频在线观看免费| 91久久久精品| 久久久久久九九| 日本亚洲欧洲色α| 国产福利视频一区| www久久99| www.午夜精品| 不卡av电影在线观看| 不卡中文字幕av| 97精品国产97久久久久久| zzijzzij亚洲日本成熟少妇| 99久久国产免费免费| 国语自产精品视频在线看| 成人精品一区二区三区电影免费| 久久精品在线免费视频| 国模无码视频一区二区三区| 久久久久久久97| 久久久97精品| 精品国模在线视频| 国产精品日日做人人爱| 国产精品久久久久久av福利 | 国产欧美高清在线| 国产精品乱码一区二区三区| 青青草精品视频在线| 97国产精品视频| 日本不卡一二三区| 国产福利视频在线播放| 97碰在线视频| 久久躁狠狠躁夜夜爽|