你好 ?
您可以找到有關 Java 效能優化技術
優化您的程式碼效能對於您的個人資料的成功至關重要。您是否知道 Akamai 的研究發現,如果頁面載入時間超過 3 秒,57% 的線上消費者就會放棄網站?在這篇文章中,您將學習如何優化 Java 程式碼並提高程式碼效能。
不再說 OutOfMemoryError: 無法建立新的本機執行緒錯誤。
Java 19 中引入的 Java 虛擬執行緒可以顯著提升專案的效能。
在 Java 的早期版本中,只有 1 種類型的線程(經典線程),當創建經典線程時,會分配作業系統線程,並且線程數量僅限於作業系統線程。
從 JDK 19 開始,您可以建立比作業系統線程輕得多的虛擬線程,並且您可以在應用程式中建立和運行數千個虛擬線程。
要在 Spring Boot 應用程式中啟用虛擬線程,請將以下程式碼新增至您的 application.properties 中。
spring.threads.virtual.enabled=true
許多效能問題都是由於取得不必要的資料而造成的。
最佳實踐是僅在需要時載入物件。
例如,您可以在 Hibernate 中使用 FetchLazy,但請始終記住,適當的獲取策略取決於您正在處理的特定用例。
fetch = FetchType.LAZY
透過快取經常存取的資料來最小化磁碟存取。透過使用適當的快取技術,您可以減少延遲、避免網路擁塞並提高內容可用性。
Spring框架提供對各種快取提供者的支持,包括但不限於Redis、Caffeie、Cache2k等...
在 JPA 中選擇金鑰產生策略時,選擇最適合您正在使用的資料庫的策略非常重要。
GenerationType.TABLE
避免使用 GenerationType.TABLE 的效能開銷。每次需要主鍵時,都會執行 LOCK 語句,以及對序列表進行選擇和更新。
GenerationType.IDENTITY
GenerationType.IDENTITY 最適合 MySQL,因為 MySQL 使用自動增量字段,而 GenerationType.IDENTITY 可以很好地配合它。
GenerationType.SEQUENCE
GenerationType.SEQUENCE 通常與 PostgreSQL 和 Oracle 一起使用。兩個資料庫都支援序列,序列是產生唯一數字序列的資料庫物件。
Hibernate 的查詢計劃快取是一個可以提高應用程式效能的關鍵功能。
當hibernate執行JPQL查詢時,就需要產生對應的SQL查詢。此過程涉及將查詢解析為抽象語法樹,將樹轉換為 SQL 查詢,最後將結果對應回 Java 物件。
此過程完成後,hibernate 會快取這個過程,以便不需要對相同查詢再次執行這些步驟。
若要啟用和設定查詢計畫緩存,請使用下列程式碼:
hibernate.query.plan_cache_max_size=2048 # 快取中查詢計畫的最大數量
hibernate.query.plan_parameter_metadata_max_size=128 # 帶有參數元資料的查詢計劃的最大大小
優化 Java 程式碼效能對於交付快速且響應迅速的應用程式至關重要。
透過利用虛擬執行緒等現代功能、實現延遲載入、使用高效的快取策略以及優化資料庫操作,您可以顯著提高應用程式的效能。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3