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

首頁 > 體育

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

來源:程序員客棧 時間:2023-06-23 08:15:32

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

青島銀行連續三年榮獲青島市“小微企業無還本續貸業務”先進單位

月子豬肝做法?-世界新視野

銀川:燒烤店燃氣爆炸,致一至二層樓梯被倒塌的建筑構筑物封堵 前沿資訊

世界觀點:國少隊U17亞少賽慘敗而歸,更該擔責的不是楊晨是足協

【新視野】畫瓷、品瓷、觀瓷,來這場瓷博會感受傳統文化之美

就業困難大學生 身邊有群熱心人 環球關注

“服務中資企業走出去,共建‘卓興魯班工坊’研討會”在寶安舉辦

國際禁毒日|天門法院集中宣判毒品犯罪案件

全球快消息!助“小巨人”長成“參天樹” 河北266個科技特派團扎根專精特新企業

天天時訊:睢寧縣2023年義務教育招生政策發布(附施教區劃分)

還原度百分百!快來學習如何精美制作秋季南瓜插花,送給好友最佳畢業禮物!

民俗文化共傳承 新鄉市衛濱區舉辦“我們的節日·端午”新時代文明實踐志愿服務活動_全球熱頭條

“古蕩鐵軍”護航亞運,構筑銅墻鐵壁

這場激烈的知識競賽在青田精彩上演!

環球熱文:別小看這些“身體信號”——愛心人壽關注年輕人健康

婁底市委常委會召開會議

今年下半年一定脫單的星座,真愛就在前方等著你!

找托納利替身,莫雷托:米蘭重新考慮簽奇克,并競爭弗拉泰西

現場默哀!銀川市長致歉:已啟動問責程序,9人被控制,并被凍結資產

端午假期預計客流超以往同期,黃浦警方提前制定大客流保障預案

速遞!氣得要死

熱點!24日至26日有一次降雨過程

【世界時快訊】新一屆團中央領導班子名單

美國海岸警衛隊確認發現失聯潛水器外部結構殘骸,搜索將繼續進行 世界熱文

讓更多老人踏上幸福旅程|焦點播報

微速訊:在家門口與“水滸108將”相會~

長沙名師大講堂聚焦“數據驅動的精準教學與評價”

【全球報資訊】現場默哀!銀川市長致歉!已啟動問責程序,9人被控制,并被凍結資產

焦點簡訊:新一輪調整周期已至?酒企三季度有望加速增長!外資堅定持有產業龍頭


主站蜘蛛池模板: 国产在线观看91精品一区| 91久久精品在线| 国产二区视频在线| 精品国产一区二区三区久久狼黑人| 日本三级久久久| 蜜臀精品一区二区| 欧美在线一级va免费观看| 久久99中文字幕| 懂色av一区二区三区四区五区| 日日碰狠狠丁香久燥| 国产精品久久久久久av| 日韩av中文字幕第一页| 婷婷四房综合激情五月| 国产欧美日韩高清| 久久久国产精品免费| 欧美日韩精品不卡| 日日骚久久av| 午夜精品蜜臀一区二区三区免费| 久久久av电影| 欧美乱妇高清无乱码| 日本国产精品视频| www国产亚洲精品| 国产精品一区二区3区| 九九精品在线观看| 日韩中文字幕亚洲精品欧美| 欧美在线视频导航| 99视频在线免费| 国产精品福利网| 亚洲精品无码久久久久久| 日韩精品无码一区二区三区免费| 国产精品乱码视频| 久久免费视频观看| 99视频在线| 亚洲a在线观看| 亚洲中文字幕无码一区二区三区| 国产精品自在线| 久久av高潮av| 久久国产乱子伦免费精品| 欧美激情国产精品| 韩国国内大量揄拍精品视频| 亚洲最大福利网|