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

首頁 > 民航

熱點聚焦:性能提升 200% !SpringBoot 虛擬線程來了

來源:程序員客棧 時間:2023-06-24 23:48:38

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

白玉蘭獎看點多,女星紅毯千姿百態,吳越拿下大獎,趙麗穎有些可惜

干豆角絲燉干豆腐的家常做法?

端午節,來打卡武漢123歲輪渡

把“空間站”建在地球上——走進我國航天領域首個大科學裝置

端午節假期出游人次破億 文旅產品服務豐富-全球快資訊

廈門地鐵6號線角美延伸段角社盾構區間實現雙線貫通

簡訊:“智能農機”讓種地更有底氣

8月1日起,在廈門過馬路低頭“刷手機” 罰款!

端午檔總票房達8.48億,暫列影史第二

美失事潛艇5名富豪或0.03秒內死亡 到底是怎么回事? 新動態

這里,成了端午節最靚的景點! 世界即時

足協杯-平科破門呂文君李圣龍建功 上海海港3-1勝廣州晉級-每日速遞

如何辨認婚禮儀式上已故親人,探討老公生日應該送什么禮物? 世界速讀

新動態:照片太大了怎么改小kb ?怎么將圖片kb壓縮變小

熱消息:《腹黑醫生愛上我》20‖雙顧(魏野)年下攻

環球觀天下!俄媒:俄南部軍區位于羅斯托夫總部大樓已被“瓦格納”包圍

上海一公共建筑突發火災

6·25號~7·10號 狗·豬·猴 最能賺錢的生肖-熱消息

天天要聞:未來兩周,運勢大旺,桃花上門,邂逅愛情,真愛相伴,甜蜜相隨

又一家!突然宣布停業!

臉上有黑痣是什么原因(為什么臉上會長痣?)_天天新視野

皮膚不好吃什么維生素(皮膚不好吃維生素E好還是維生素C好)|全球播報

有人問行業分析的數據從哪里找

過度喂養是傷害!判斷孩子是否吃飽,看這些信號就夠了

“瓦格納”稱占領俄南部軍區指揮部_聚看點

2023河南美術生本科分數線多少分(含2021-2022年) 全球微速訊

2023年云南普通高校招生網上填報志愿考生須知

超任經典《超級瑪利歐RPG》重制版發表,碧姬公主全新作蓄勢待發

與D3一樣,暴雪確認《暗黑破壞神4》每次戰斗通行證賽季皆需重練新角色


主站蜘蛛池模板: 日韩在线视频免费观看高清中文 | 亚洲国产精品www| 欧美在线播放一区二区| 精品成在人线av无码免费看| 国产精品永久免费视频| 精品国偷自产一区二区三区 | 国产精品成人av性教育| www.av中文字幕| 日本不卡一区| 国产三级中文字幕| 一区二区视频国产| 欧美激情久久久久久| 国产精品丝袜一区二区三区| 少妇免费毛片久久久久久久久| 亚洲91精品在线观看| 久久久久久av| 91久久久久久久久久久久久| 日本一区二区三区视频免费看| 久久精品视频免费播放| 国产精品大全| 国产福利一区二区三区在线观看| 欧洲精品久久久| 99视频在线播放| 国产日韩欧美另类| 91久久久久久久一区二区| 久久av中文字幕| 午夜久久资源| 国产精品毛片a∨一区二区三区|国| 日韩中文字幕在线不卡| 国产精品情侣自拍| 欧美精品日韩三级| 91精品成人久久| 国产女精品视频网站免费| 99精品免费在线观看| 久久精视频免费在线久久完整在线看| 国产女人18毛片水18精品| 精品国产免费av| 国产中文字幕91| 俄罗斯精品一区二区| 99久久久精品视频| 亚洲精品第一区二区三区|