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

首頁 > 讀書

全球微動態丨性能提升 200% !SpringBoot 虛擬線程來了

來源:程序員客棧 時間:2023-06-23 07:19:23

在以往的項目中,我們面臨了這樣一種情況:我們收到了數千個認證請求。為了確保安全性,我們依靠第三方系統發送短信 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 虛擬線程來了

全球快看:武漢經開區紗帽街道多部門聯動,開展再生資源回收行業專項整治

觀熱點:為拿獎鋪墊?白玉蘭評委稱流量不是原罪,展映又增朱一龍作品

恒生指數21日收跌1.98% 互聯網科技股集體下挫

天天百事通!漯河:最新任命!

河南省雜技集團赴美演出再啟程_世界今日訊

環球視訊!蓮都初一女生可免費接種HPV疫苗啦!

【全球獨家】痛風可以吃魚嗎?為什么?

我在南沙這一年⑦|港科大(廣州)協理副校長熊輝:為南沙集聚高層次人才,探索知識轉移“從0到1到n”

20.3億元!增速全省第四 世界快消息

2023青島國際顯示大會在青島西海岸新區開幕 當前快報

瑞典樓市現轉機?5月新屋開工率近兩年來首次上升|每日快播

全球看熱訊:(圖表)[財經·行情]國際油價6月21日上漲

宏柏新材(605366)6月21日主力資金凈賣出85.63萬元

全球新消息丨如何處罰抗稅罪 抗稅罪的量刑標準是什么 天天熱資訊

世界速讀:福島民眾:排污入海讓多年努力成泡影

全球播報:國鐵集團:今日全國鐵路預計發送旅客1620萬人次

好消息!渝昆高鐵華福特大橋建設進度條更新了

AMD贊助游戲排斥NVIDIA技術?官方回應耐人尋味

當前觀點:二手房產過戶費有哪些

扎根海島二十載 問天探蟲護糧安 世界觀天下

品牌聯動強化消費者服務 蒙牛摘得“京東618”八連冠

全球通訊!三星27英寸S95K顯示器上架:11499元

未來8天,四大生肖財運入宮,財運超旺,日子富裕

融通基金萬民遠:醫藥行業有望實現穩健發展

每日熱門:釋放經濟新活力 假期民俗文化熱潮帶動消費市場持續升溫

桓臺縣索鎮街道蘇王村開展反養老詐騙宣傳活動|全球觀天下

我國最長深水油氣管道鋪設完工-世界微動態

首宗個人破產案債務人獲經濟“重生” 天天快看點

水庫“減肥健體”河床“舒筋通絡” 今年黃河調水調沙正式啟動-每日簡訊


主站蜘蛛池模板: 精品国产中文字幕| 国产女人精品视频| 不卡日韩av| 日韩在线视频在线观看| 国产精品香蕉国产| 日韩经典在线视频| 国产精品久久久久久久久久ktv| 国产日韩一区二区在线观看| 欧美在线视频二区| 亚洲中文字幕无码av永久| 欧美 国产 综合| 婷婷五月综合缴情在线视频 | 日韩色av导航| 国产高清自拍99| 久久久国产精品免费| 久久av高潮av| 日韩视频在线观看视频| 国产精品久久久久99| 欧美乱大交xxxxx潮喷l头像| 久久精品国产91精品亚洲| 国产精品激情自拍| 国产综合免费视频| 久久99导航| 日韩在线视频线视频免费网站| 91精品在线国产| 91国产精品91| 国产欧美日韩视频| 免费国产成人av| 视频一区二区三区免费观看| 欧日韩一区二区三区| 久久99精品久久久久久水蜜桃| 中文字幕精品一区日韩| 亚洲人成网站在线播放2019| 91久久久久久久一区二区| 成人h视频在线观看| 国产ts人妖一区二区三区| 国产精品麻豆va在线播放| 久久九九视频| 欧美精品在线播放| 久久国产午夜精品理论片最新版本| 日韩精品成人一区二区在线观看|