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

首頁 > 教育頻道

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

來源:程序員客棧 時間:2023-06-23 18:42:36

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

北京到蘭州火車時刻表查詢8.28(北京到蘭州火車時刻表)_每日快播

源代碼和工具 | 2023 bilibili 視頻評論爬蟲,單條視頻最多可爬取 10000 條評論

煙臺市牟平區海德小學開展“濃情端午 粽享安康”系列活動

王菲長女進軍電視圈!新劇搭檔王傳君,遮掉臉上紋身留長發顯清純

每日觀察!筷子兄弟打王太利_筷子兄弟做客快本

2023石家莊汽車消費券在哪里領?

焦點速讀:2023石家莊端午節旅游包車高速免費最新通知

歡天喜地九仙女_歡天喜地九仙女劇情

世界信息:廣州蘇醒演唱會2023在哪舉行(附交通指南)

披荊斬棘同義詞-環球通訊

當前時訊:豬蹄與豬肉哪個油脂大?

天天播報:小聯賽重心:辛辛那提主場無敵,多倫多FC客戰奇差

萊昂納德接受膝蓋手術,需要8周時間康復|當前視訊

夏季不想被蚊蟲“親吻”,請get這些小妙招! 環球聚焦

每日看點!歐元/日元匯率今日預期趨勢:看漲(2023/6/21)

國聯證券:維持美麗田園醫療健康買入評級 目標價33.8港元

高薪留人、股權激勵:四大豬企簽互不挖人公約背后人才爭奪激烈 天天信息

標準俯臥撐教程_標準俯臥撐做法視頻-世界視訊

強智系統吉首大學學生登錄入口_強智系統吉首大學

餡餅的面怎樣和做出來的餡餅才又軟又薄_做餡餅的面怎么和 世界播報

微信拍一拍的備注怎么改_微信拍一拍的備注改的方法

環球快播:2023“白塔杯”文化創意大賽正式啟動征集

微研報:新能源汽車呈現加速滲透趨勢 國內市場共振帶來新的增量需求

三花控股集團計劃退出房地產業務 去年地產收入逾16億-速看

辛辛苦苦好幾年一下回到解放前,保羅或重回快船,球迷的評論亮了 當前最新

架起生命急救“高速路” 新疆首設高速公路醫療急救服務中心

這個600畝的農業園區里,藏著全省70%耕地增產增收的“秘訣” 新要聞

word文檔不顯示修改內容_word文檔不顯示修改痕跡

孩子積食怎么調理_孩子積食怎么快速消食|世界觀焦點


主站蜘蛛池模板: 久久激情五月丁香伊人| 91精品国产乱码久久久久久久久| 欧美在线一级va免费观看| 色婷婷成人综合| 国产精品高潮在线| 精品激情国产视频| 萌白酱国产一区二区| 日本精品福利视频| 日韩在线不卡视频| 亚洲国产日韩欧美| 91国在线精品国内播放| 国产精品久久久久av免费| 国产日韩亚洲欧美| 国内一区二区在线视频观看| 麻豆久久久9性大片| 欧美日韩成人精品| 欧美一区二视频在线免费观看| 国产精品av电影| 久久久久久久国产精品视频| 日本免费高清一区| 日韩欧美视频网站| 日本一区高清在线视频| 日韩一区二区三区在线播放| 亚洲一区二区在线看| 中文字幕日韩精品一区二区| 91久久久亚洲精品| 91精品国产精品| 99亚洲国产精品| 777午夜精品福利在线观看| 99久久久精品视频| 亚洲午夜精品一区二区三区| 亚洲一区尤物| 日韩不卡视频一区二区| 日韩久久久久久久久久久久久 | 日本视频久久久| 日韩av一区二区三区在线| 色综合久久中文字幕综合网小说| 亚洲欧美日韩精品综合在线观看| 亚洲一区二区三区在线观看视频| 一区二区在线高清视频| 日韩精品久久久|