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

首頁 > 娛樂頻道

性能提升 200% !SpringBoot 虛擬線程來了|世界報資訊

來源:程序員客棧 時間:2023-06-24 13:02:51

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

成都大運會火炬傳遞重慶站啟動

我國前5個月光伏裝機和海關數據,隱藏著一個驚人真相! 全球聚焦

寶馨科技:蓄勢待發!光伏電池+充/換電業務雙引擎催股價沖高|大漲解讀

中國開源,邁入“新生代”

注意!7月8日—9日南寧小學初中新生統一報名

天天簡訊:廈門集美怎么查看社保累計交了多少年,如何查詢社保累計繳費年限?

端午假期交通部門加強多種出行方式聯動 每日快播

云南將組織開展文化科技衛生“三下鄉”集中示范活動 當前播報

一張粽葉包萬物!700多年前的粽子長什么樣?

好的,我的建議是:如何運用創意制作男生生日禮物——衣架? 天天視訊

全球觀點:曝開拓者將全力留下利拉德:掛斷了所有交易電話

官方:“水稻上山”不是“毀林造田”,更不是“退林還耕”_世界新資訊

一鍵重裝電腦系統哪個最好

前五個月電信業務總量保持較快增長

廣元朝天:生態避暑游 假期好去處-今熱點

每日觀點:澤連斯基要求烏軍總司令解除敖德薩征兵委員會負責人職務

暴雨中的守護:一面錦旗道出背后暖心事_觀速訊

莫斯科市長:目前正進行反恐行動,希望市民理解

公雞突然從背后“偷襲”萌娃 飛起兩腳踹倒在地 第二天端午節就被燉了

歐洲通信衛星公司與du合作,促進中東和北非的廣播服務_全球看點

焦點消息!新款皇冠系列雙車登場

【全球獨家】廣西北部灣發生5.0級地震 暫未收到人員傷亡報告

多彩活動慶端午 天山南北共安康

當前報道:海陵區召開旅游環境整治工作會議

農歷六月,屬兔、牛、虎運勢提點,貴人庇護,開心掙大錢。|世界速讀

國際范兒,龍舟“劃”向世界!端午節已成全人類共同文化遺產_今日最新

“為防范中國”,日防衛省決定擴編“水陸機動團”|每日快訊

支持載波聚合的鼎橋5G CPE Ins 5發布 當前快訊

【報資訊】無錫多項減負舉措助力基層干部“輕裝上陣”


主站蜘蛛池模板: 国产精品自拍首页| 久久精品女人的天堂av| 国产精品日韩在线播放| 国产九九九九九| 久久久久久久久久久久av| 久久精品国产视频| 国产精品美女久久久久久免费| 色综合久久天天综线观看| 日本久久久网站| 国产精品美女网站| 国产尤物91| 欧美中日韩一区二区三区| 福利视频久久| 一区二区三区四区视频在线观看| 精品中文字幕在线观看| 亚洲精品一区二区三| 国产精品久久久久77777| 国产欧美日韩中文字幕| 一区二区三区四区不卡| 久久国产精品久久| 亚洲综合日韩中文字幕v在线| 精品国产免费人成电影在线观...| 国产欧美日韩在线播放| 国产精品久久久久久久久免费看| 久久资源av| 91精品久久香蕉国产线看观看| 久久综合中文色婷婷| 欧美日韩精品中文字幕一区二区| 精品一区二区三区自拍图片区| 秋霞无码一区二区V| 日日骚久久av| 91九色国产社区在线观看| 黄色片免费在线观看视频| 欧美高清视频一区二区三区在线观看| 欧美高清视频一区| 国产一区二区在线免费| 蜜桃视频一区二区在线观看| 麻豆久久久9性大片| 国产精品麻豆va在线播放| 色综合久久中文字幕综合网小说| 久久福利视频导航|