久久久噜噜噜久久熟女,久久久久久久久,国内精品,精品国产成人亚洲午夜福利,久久天堂av综合合色蜜桃网,好姑娘在线观看完整视频高清

首頁 > 親子

性能提升 200% !SpringBoot 虛擬線程來了-焦點(diǎn)快報

來源:程序員客棧 時間:2023-06-22 16:50:49

在以往的項目中,我們面臨了這樣一種情況:我們收到了數(shù)千個認(rèn)證請求。為了確保安全性,我們依靠第三方系統(tǒng)發(fā)送短信 OTP 進(jìn)行驗證。然而,有時候第三方系統(tǒng)花費(fèi)的時間比預(yù)期的要長,導(dǎo)致延遲。我們采用了每個請求一個線程的模型,這意味著許多線程處于等待狀態(tài),并且新請求都在隊列中。我們試圖通過微調(diào)線程數(shù)量來優(yōu)化性能,但當(dāng)時我們希望有虛擬線程功能。當(dāng)時 Java 中沒有虛擬線程的概念,這就是 Project Loom 的作用。

虛擬線程
什么是 Project Loom?

什么是 Project Loom?這是 Oracle 的一個新項目,主要目標(biāo)是顯著減少編寫、維護(hù)和觀察高吞吐量并發(fā)應(yīng)用程序的工作量。換句話說,Project Loom 旨在支持和推進(jìn)一個高吞吐量、輕量級的 Java 并發(fā)模型,因為傳統(tǒng)的操作系統(tǒng)線程(Java 并發(fā)模型的核心)有一些缺點(diǎn),并且在計算上相當(dāng)昂貴。反之,虛擬線程是更輕量級的線程,不與操作系統(tǒng)線程連接(由 JVM 管理)。這意味著虛擬線程是“每請求對應(yīng)一個線程”編程的理想選擇,可以創(chuàng)建大量的虛擬線程,而不會降低吞吐量。開發(fā)人員可以使用現(xiàn)有的 JDK 工具和技術(shù)快速排除故障、調(diào)試和分析并發(fā)應(yīng)用程序,在發(fā)布的 Spring Boot 3.1 中可用。作為 Spring 開發(fā)者,了解虛擬線程的概念并理解它們在開發(fā)過程中的重要性非常關(guān)鍵。

如何使用虛擬線程Java 版本選擇

Java 19 中引入的虛擬線程非常易于使用,筆者使用的 Mac M1 系列,這里選擇 Azul Zulu 發(fā)行版 20.30.11 版本[1]


(資料圖)

azul 20
創(chuàng)建測試項目

使用 Spring Initializer 或 IDE 創(chuàng)建項目。添加 spring-web 依賴項并添加元數(shù)據(jù)。(注意版本選擇 SpringBoot 3.1 ,Java 20)

開啟虛擬線程功能
默認(rèn)報錯

默認(rèn)情況下, Java19 的虛擬線程功能是禁用狀態(tài)的,需要通過相關(guān) 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 協(xié)議處理器,負(fù)責(zé)處理 Spring Boot 應(yīng)用程序中傳入的請求。這個自定義程序的目的是配置協(xié)議處理器使用的執(zhí)行器。

在 threadExecutorCustomizer 方法內(nèi)部,使用 Lambda 表達(dá)式來自定義協(xié)議處理器。protocolHandler 參數(shù)代表正在自定義的 Tomcat 協(xié)議處理器的實例。

在 Lambda 表達(dá)式中,調(diào)用 protocolHandler 對象的 setExecutor() 方法,用于為協(xié)議處理器設(shè)置執(zhí)行器。執(zhí)行器負(fù)責(zé)執(zhí)行任務(wù),例如處理傳入的請求。

在這種情況下,使用 Executors.newVirtualThreadPerTaskExecutor() 方法創(chuàng)建一個新的使用虛擬線程的執(zhí)行器。虛擬線程是輕量級線程,可以在單個操作系統(tǒng)線程中并發(fā)執(zhí)行任務(wù)。這意味著可以同時執(zhí)行多個任務(wù),提高性能和資源利用率。

增加測試端點(diǎn)

@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 獲取當(dāng)前請求線程的元信息,以判斷虛擬線程是否已經(jīng)正確開啟。

性能測試對比100 線程測試不開啟虛擬線程
吞吐量 300/s
開啟虛擬線程
吞吐量 300/s
300 線程測試不開啟虛擬線程
吞吐量 650/s
開啟虛擬線程
吞吐量 950/s
500 線程測試不開啟虛擬線程
吞吐量 650/s
開啟虛擬線程
吞吐量 1500/s
圖表輸出總結(jié)

通過以上我們發(fā)現(xiàn),在處理阻塞操作時,虛擬線程特別有益。隨著并發(fā)請求數(shù)量的增加,虛擬線程的性能提升越來越明顯。上述測試都是在未對 Spring Boot 項目進(jìn)行調(diào)優(yōu)和優(yōu)化的情況下進(jìn)行的。

參考資料[1]

Azul Zulu 發(fā)行版 20.30.11 版本: https://www.azul.com/downloads/?version=java-20-sts&os=macos&architecture=arm-64-bit&package=jdk#zulu

相關(guān)稿件

性能提升 200% !SpringBoot 虛擬線程來了-焦點(diǎn)快報

100種分析思維模型之:故事思維 天天滾動

世界熱門:《偷偷藏不住》段嘉許桑稚年齡差幾歲 段嘉許什么時候喜歡桑稚

姚記科技:股東擬減持不超過0.01%的股份

今日訊!渤海油田累計生產(chǎn)原油突破5億噸

寧夏銀川燒烤店爆炸事故已造成31人死亡

環(huán)球熱資訊!航行警告!南海海域軍事訓(xùn)練

天天熱點(diǎn)!彌生時代的特征有哪些?又有什么變化存在?

熱議:【家電】小米空調(diào)與松下達(dá)成戰(zhàn)略伙伴關(guān)系 將聯(lián)合打造家電新品

女人36歲補(bǔ)膠原蛋白有用嗎?

全球快資訊丨銀行板塊跌0.29% 建設(shè)銀行漲0.97%居首

君實生物創(chuàng)新低 2020年A股上市即巔峰兩募資共86億 世界短訊

造謠買到農(nóng)夫山賊礦泉水者被行拘

我省已獲批5家人類遺傳資源樣本庫 焦點(diǎn)熱門

全球今頭條!2023年健康中國行暨青海省第二十三屆健康教育萬里行活動啟動

穩(wěn)下來,好起來

俄羅斯最新型護(hù)衛(wèi)艦“尖銳”號試射巡航導(dǎo)彈

三大利空!滬指跌破3200,人民幣跌破7.2,外資下調(diào)中國GDP預(yù)測 全球今日訊

三連跌!恒生指數(shù)收跌1.98%,科技股跌幅居前|當(dāng)前快訊

端午節(jié)為何要懸掛艾草、佩香囊?-世界熱資訊

高溫日歷出爐!北方多地將現(xiàn)今年來最長連續(xù)高溫

熱議:月兔漫游怎么解鎖新地點(diǎn) 月兔漫游中國之家攻略

歌詩圖和途觀哪個好?外觀、配置、性能、價格對比全解析!

跨界電商直播三個月突圍而出,TVB識貨618告捷:GMV破億,刷新自身紀(jì)錄 速看

當(dāng)前信息:武漢紡織大學(xué):紅色“微黨課”提升學(xué)子黨性修養(yǎng)

山東學(xué)生注意!計劃外國際本科注意這3點(diǎn),??品?jǐn)?shù)也能讀!|每日快報

*ST金山: 公司2022年年度報告中的研發(fā)投入嚴(yán)格按照《企業(yè)會計準(zhǔn)則第6號-無形資產(chǎn)》的相關(guān)規(guī)定編制

當(dāng)前觀察:10 分鐘玩轉(zhuǎn)Elastcisearch——數(shù)據(jù)可視化分析

世界滾動:好消息!渝昆高鐵華福特大橋建設(shè)進(jìn)度條更新了

武漢樓盤交付喜憂參半:有項目提前66天交付,有項目交付即維權(quán)