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

首頁 > 收藏

性能提升 200% !SpringBoot 虛擬線程來了|天天快看

來源:程序員客棧 時間:2023-06-23 21:02: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 虛擬線程來了|天天快看

世界微資訊!一別77年!她終于與烈士哥哥“重逢”……

一元搶購汽車_一元秒殺汽車 聚看點

博愛牛肉丸子的正宗做法?

環球精選!直搗黃龍猜一數字_直搗黃龍

全球信息:劍網三老君爐在哪_劍網3老君爐

當前動態:湖北陽新:打好生態旅游牌 將美景變“錢景”

環球新資訊:IP屬地顯示需加中國?深意何在?(25字)

今年夏天,極端高溫是否會成為常態?

第四屆世界青少年象棋錦標賽選拔賽在亳州拉開戰幕

《王小波傳》⑤|當老師,也沒改變他的叛逆

忙直播的羅永浩,還做不做AR了?

全球聚焦:創意DIY禮物集錦:為愛人慶生或父親節送上特別的驚喜與感動

Todd Howard告訴你《星空》一千個星球上有什么 當前熱文

《天外世界2》尚未決定是否為Xbox獨占有可能也登PS5 全球熱點評

館體建筑存在重大安全隱患 銀川市圖書館發布閉館公告

端午養生 | 跟我做好4件事,告別“苦夏”,養出“精氣神”~

環球微頭條丨今年最火的裙子,舒服又涼快

焦點速遞!讀創公司調研|鄭中設計:積極發展主業,加強軟裝業務的拓展及團隊建設

波波維奇翻跟頭,名記披露 全球看熱訊

異性之間:真愛相遇,體現在3個細節變化里_當前熱點

每日快報!完全的愛贊美詩(完全的愛)

新創建集團(00659)6月23日下午盤中短暫停牌 原因未知

每日快播:每日電動車行業動態匯總(6月23日)

收費站暖心幫助迷路老人回家

全球觀點:五顏六色的的服飾絢爛多彩,2種搭配方式,教你玩轉整個夏天

每日速訊:找回《紅樓夢》80回后曹雪芹文筆的著名作家唐國明,是如何完成啟蒙教育的

【世界快播報】那些讓人醍醐灌頂、人間清醒的觀點!

今年618,淘寶請梅西來直播,釋放了怎樣的信號?_全球觀點

恐龍為何沒進化智慧? 當前快訊


主站蜘蛛池模板: 国产极品尤物在线| 日韩欧美视频一区二区三区四区 | 午夜精品蜜臀一区二区三区免费| 国产日韩欧美中文在线播放| 久久久久久国产精品美女| 欧美成人中文字幕| 日韩视频一区在线| 日韩中文字幕一区| 日本一区二区三区在线播放| 日本精品一区二区三区高清 久久 日本精品久久久久中文字幕 | 久久男人的天堂| 欧美日韩不卡在线视频| 日本国产精品视频| 欧美精品久久久久久久久久久| 欧美精品在线第一页| 久久男人的天堂| 国产在线观看精品一区二区三区| 国产男人精品视频| 国产精品欧美激情| 国产精品亚洲天堂| 国产成人综合精品| 在线一区亚洲V| 色天天综合狠狠色| 日本一区二区三区视频在线播放| 欧美一区二区三区精美影视| 久久精品视频在线播放| 国产精品一 二 三| 91久热免费在线视频| 天天成人综合网| 久久亚洲a v| 国产日韩av在线播放| 在线免费一区| 美日韩精品免费观看视频| 精品久久久久久无码中文野结衣 | 国产精品激情av在线播放| 亚洲午夜精品国产| 欧美日韩电影在线观看| 国产日韩欧美中文| 一区二区三区四区欧美日韩| 欧美在线视频导航| 国产精品日韩在线一区|