你的Spring應用啟動很慢?不妨試試這個工具!

来源:https://www.cnblogs.com/didispace/archive/2023/07/24/17576446.html
-Advertisement-
Play Games

睡不著閑逛,在GitHub上看到一個挺實用的開源項目:**Spring Startup Analyzer**。 從項目名稱中就大概能猜到,這是一個分析Spring應用啟動過程的工具。Spring Startup Analyzer通過採集Spring應用啟動過程的數據,進而生成一個互動式的分析報告,幫 ...


睡不著閑逛,在GitHub上看到一個挺實用的開源項目:Spring Startup Analyzer

從項目名稱中就大概能猜到,這是一個分析Spring應用啟動過程的工具。Spring Startup Analyzer通過採集Spring應用啟動過程的數據,進而生成一個互動式的分析報告,幫助用戶發現Spring應用啟動慢的位置。

同時,Spring Startup Analyzer還提供了Spring Bean非同步初始化的工具,來幫助開發者加快Spring應用的啟動時間。

下麵一起來看看其提供的強大功能。

分析能力

我們可以先從該項目中給出HTML樣例報告來看看它所提供的分析功能。感興趣的可以通過下麵鏈接訪問:

把報告內容的細節部分都收起來,可以看到如下圖所示的內容:

主要有六個部分:

  • 啟動的統計數據。其中包括:啟動時間、Bean的數量、使用/總共的JAR包數量、未使用/總共的JAR包數量、ClassLoader數量

  • Spring Bean初始化數據。這裡採集了每個Spring Bean的初始化時間及其細節內容

  • Bean初始化時間線。通過時間線的方式,清晰地展現了Spring應用啟動時候,各個Bean的順序關係以及時間消耗

  • 方法調用的詳細信息。這裡統計了每個方法的調用時間、總時間開銷和每次調用的平均時間

點開之後,還能看到具體每次調用時候的時間開銷和一些調用細節:

  • 啟動後未使用的JAR。列出了所有Spring應用啟動後沒有使用的jar包,可以有效的幫助你清理不需要的依賴,為應用瘦身

  • 應用啟動過程的線程火焰圖

如何使用

通過上面的介紹,相信你已經瞭解該工具的強大之處了。接下來就可以通過下麵的方法嘗試分析一下自己的應用吧:

第一步:從裡面的鏈接中下載最新的安裝包

https://github.com/linyimin0812/spring-startup-analyzer/tags

第二步:解壓下載的安裝包,記住解壓後的路徑,下麵一步要用

第三步:編輯Spring Boot的啟動參數,包括:

  1. 該工具採用agent的方式啟動,所以要添加參數-javaagent:$HOME/spring-startup-analyzer/lib/spring-profiler-agent.jar,這裡$HOME代表以前的解壓路徑,記得根據上面解壓後的路徑編輯這個參數
  2. 配置分析工具的參數,這裡根據自己需要添加即可,比如可以配置超時時間30分鐘:-Dspring-startup-analyzer.app.health.check.timeout=30,其他可配置項如下表,你可以工具自己應用的情況去修改:

第四步:查看該工具的日誌,可以通過$HOME/spring-startup-analyzer/logs路徑,這裡$HOME代表以前的解壓路徑,日誌文件的類別為:

  • startup.log: 啟動過程中的日誌
  • transform.log: 被re-transform的類/方法信息

另外,該工具還支持自定義擴展,這裡DD沒試過,就不具體介紹了。感興趣的童鞋可以根據文檔去試試。

啟動優化

這裡提到了一個啟動加速的優化思路,就是把一些耗時的Bean初始化改成非同步就能實現。該項目提供了Bean的非同步初始化工具,也非常好用,只需要下麵幾步就能完成。

第一步:引入依賴

<dependency>
    <groupId>io.github.linyimin0812</groupId>
    <artifactId>spring-async-bean-starter</artifactId>
    <version>2.0.2</version>
</dependency>

第二步:配置參數

# 非同步化的Bean可能在Spring Bean初始化順序的末尾,導致非同步優化效果不佳,打開配置優先載入非同步化的Bean
spring-startup-analyzer.boost.spring.async.bean-priority-load-enable=true
# 指定非同步的Bean名稱
spring-startup-analyzer.boost.spring.async.bean-names=testBean,testComponent
# 執行非同步化Bean初始化方法線程池的核心線程數
spring-startup-analyzer.boost.spring.async.init-bean-thread-pool-core-size=8
# 執行非同步化Bean初始化方法線程池的最大線程數
spring-startup-analyzer.boost.spring.async.init-bean-thread-pool-max-size=8

第三步:檢查Bean是否非同步初始化。查看日誌$HOME/spring-startup-analyzer/logs/startup.log文件,對於非同步執行初始化的方法,會按照以下格式寫一條日誌:

async-init-bean, beanName: ${beanName}, async init method: ${initMethodName}

但是,作者在文檔中也提到了,非同步並不是萬能的,你還需要註意以下這幾點:

  • 應該優先從代碼層面優化初始化時間長的Bean,從根本上解決Bean初始化耗時長問題
  • 對於二方包/三方包中初始化耗時長的Bean(無法進行代碼優化)再考慮Bean的非同步化
  • 對於不被依賴的Bean可以放心進行非同步化,可以通過各個Bean載入耗時中的Root Bean判斷Bean是否被其他Bean依賴
  • 對於被依賴的Bean需要小心分析,在應用啟動過程中不能其他Bean被調用,否則可能會存在問題

好了,今天的學習就到這裡!如果您學習過程中如遇困難?可以加入我們超高質量的Spring技術交流群,參與交流與討論,更好的學習與進步!更多Spring Boot教程可以點擊直達!,歡迎收藏與轉發支持!

最後,奉上項目地址:https://github.com/linyimin0812/spring-startup-analyzer

歡迎關註我的公眾號:程式猿DD。第一時間瞭解前沿行業消息、分享深度技術乾貨、獲取優質學習資源


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • # Class類 ## **基本介紹** 1. Class也是類,因此也繼承Object類; 2. Class類對象不是new出來的,而是系統創建的; 3. 對於某個類的Class類對象,在記憶體中只有一份,因為類只載入一次; 4. 每個類的實例都會記得自己是由哪個Class實例所生成的; 5. 通過 ...
  • 有一位同事說使用 fastjson 進行 JSON 序列化存儲到資料庫後,發現 JSON 字元串“莫名其妙地”多了一些屬性!幫看了下代碼,看到基本類型的布爾類型以 is 開頭的屬性,再看到 fastjson ,就有點想笑。 ## 復現 定義 MyClass ``` public class MyCl ...
  • [TOC](【後端面經-Java】String與StringBuffer與StringBuilder的比較) ## 1. String 1. 不可變 查看`String`源碼如下: ```java public final class String implements java.io.Serial ...
  • golang的泛型已經出來了一年多了,從提案被接受開始我就在關註泛型了,如今不管是在生產環境還是開源項目里我都寫了不少泛型代碼,是時候全面得回顧下golang泛型的使用體驗了。 先說說結論,好用是好用,但問題也很多,有些問題比較影響使用體驗,到了不吐不快的地步了。 這篇文章不會教你泛型的基礎語法,並 ...
  • 最近在寫代碼時發現一個很有意思的問題 問題代碼: 1 // 1.準備一個集合,排序。 2 List<Movie> movies = new ArrayList<>(); 3 movies.add(new Movie("摔跤吧,爸爸", 9.5, "阿米爾汗")); 4 movies.add(new ...
  • 在Windows中, 將文件用滑鼠拖動到一個程式上面, 會有一句小提示: 用 xxx 打開(如下圖)。 它本質上就是運行程式時, 傳遞了一個文件路徑的命令行參數。 相當於這樣的命令: program.exe file_path 其中"program.exe"就是打開此文件用的程式, "file_pa ...
  • #### 前言 個人項目開發中,網站建設中需要用到大量的圖片以及用戶上傳的圖片,如果伺服器帶寬小,磁碟容量小將所有的圖片信息全部存儲在伺服器上不太現實,這裡建議將圖片數據存儲在對象存OSS上或者將圖片保存在圖床上,減少帶寬費用節約成本。 #### 項目環境 ``` SpringBoot:3.x JD ...
  • 簡介: 在現代軟體開發中,全球唯一標識符(UUID)在許多場景中發揮著重要的作用。UUID是一種128位的唯一標識符,它能夠保證在全球範圍內不重覆。在Go語言中,我們可以使用第三方庫`github.com/google/uuid`來方便地生成UUID。本文將介紹如何使用這個庫來生成不同版本的UUID ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...