Java性能優化權威指南-讀書筆記(五)-JVM性能調優-吞吐量

来源:http://www.cnblogs.com/xiongpq/archive/2016/12/11/6160044.html
-Advertisement-
Play Games

吞吐量是指,應用程式的TPS: 每秒多少次事務,QPS: 每秒多少次查詢等性能指標。 吞吐量調優就是減少垃圾收集器消耗的CPU周期數,從而將更多的CPU周期用於執行應用程式。 CMS吞吐調優 CMS包括Minor GC所帶來的開銷應該小於10%,如果垃圾收集的開銷在3%或更少,說明通過調優吞吐量,提 ...


吞吐量是指,應用程式的TPS: 每秒多少次事務,QPS: 每秒多少次查詢等性能指標。

吞吐量調優就是減少垃圾收集器消耗的CPU周期數,從而將更多的CPU周期用於執行應用程式。

CMS吞吐調優

CMS包括Minor GC所帶來的開銷應該小於10%,如果垃圾收集的開銷在3%或更少,說明通過調優吞吐量,提升性能的空間就極其有限了。

可用的調優方法如下:

1. 增大新生代空間,以降低Minor GC頻率,減少CPU周期占用;

2. 增加老年代空間,以降低CMS頻率,並可以減少老年代記憶體碎片;

3. 優化CMS周期的啟動條件,儘可能在較晚的時候進行;

總的來說,就是減少垃圾收集占用的CPU周期。

ParallelGC吞吐調優

這裡說的ParallelGC是指開啟了下麵兩個JVM參數

-XX:+UseParallelGC
-XX:+UseParallelOldGC

對ParallelGC調優的目標是儘可能避免發生Full GC,這就需要優化對象老化頻率,可以調整Survivor空間實現對對象老化的優化。

使用ParallelGC時,垃圾收集的開銷應小於5%,如果已經減少到1%甚至更少,那基本上就已經達到了極限。

Survivor調優

ParallelGC預設可以自動調整Survivor空間,大部分應用用自動調整已經可以,對要求比較高的應用就需要關閉自動調整,進行手動調整。

為JVM添加下麵兩個參數,只針對ParallelGC有用:

-XX:-UseAdaptiveSizePolicy     //關閉自適應調整
-XX:+PrintAdaptiveSizePolicy   //列印詳細Survivor空間占用日誌

如下麵日誌:

2016-12-11T16:44:03.653+0800: 5.042: [GC (Allocation Failure) AdaptiveSizePolicy::update_averages:  
survived: 10464720  
promoted: 1096456  
overflow: true

survived:“TO”Survivor空間占用大小;

promoted: 新生代提升至老年代的對象大小;

overflow:是否有Survivor空間的對象溢出到老年代;

從上面的日誌可以看出,Minor GC後新生代存活對象大小10M,因為沒有設置-XX:TargetSurvivorRatio,預設Survivor空間占用比率為50%,

所以Survivor空間應為20M。

 

找到穩定態下Full GC之間所有Minor GC中最大的存活對象大小,然後就可以調整Survivor空間大小。

原JVM參數如下:

-Xmx1024m –Xms1024m –Xmn50m -XX:SurvivorRatio=3

可以計算出:原Survivor空間:10M,原Eden空間:30M

現在增大Survivor空間到20M

保證Eden空間不變,則新生代大小為70M;

70M / (SurvivorRatio + 2)=20M,所以SurvivorRatio=1.5

保證老年代空間不變,則Java堆大小調整為1044M

所以最後JVM參數為:

-Xmx1044m -Xms1044m -Xmn70m -XX:SurvivorRatio=1.5

如果Java堆大小已經不能再增大,可以計算下Minor GC後,存活對象的最小值、最大值、平均值,如果不存在大幅波動,

可以嘗試提高Survivor空間的占用百分比-XX:TargetSurvivorRatio=<n>,其預設為50%。

並行線程調優

-XX:ParallelGCThreads  

並行垃圾收集器的線程數,建議收集線程數設置的小於預設值,否則大量GC線程會影響應用性能

其他性能命令行選項

-XX:+AggressiveOpts 自動優化,但有可能不太穩定
-XX:+DoEscapeAnalysis 逃逸分析
-XX:+UseBiasedLocking 偏向鎖
-XX:+UseLargePages 大頁面支持

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

-Advertisement-
Play Games
更多相關文章
  • 加上這個設置編碼格式就好了,最好在頁面也加設置下utf-8 ...
  • 根據代碼來分析鏈表的操作 eg: 1.定義一個結構體,並定義一個表頭指針 2.編寫main函數 main函數主要接收外面傳進來的參數,作出一系列操作。 l:顯示所有的名字 a:添加一個名字 d:刪除一個名字 x:退出操作 3.完善各個函數的編寫 3.1 add_one_name和add_name函數 ...
  • 設計模式(Design Patterns) ——可復用面向對象軟體的基礎 設計模式(Design pattern)是一套被反覆使用、多數人知曉的、經過分類編目的、代碼設計經驗的總結。使用設計模式是為了可重用代碼、讓代碼更容易被他人理解、保證代碼可靠性。 毫無疑問,設計模式於己於他人於系統都是多贏的, ...
  • 需求:使用IO流將一個文件的內容複製到另外一個文件中去 文件"good boy.txt"位於D盤根目錄下,要求將此文件的內容複製到c:\\myFile.txt中 代碼: import java.io.*; public classInputAndOutputFile{ public static v ...
  • An internal error occurred during: "Initializing Java Tooling".java.lang.NullPointerException ...
  • String擁有一個特殊點叫:String對象的內容不可改變! 在調用諸如String對象的replace()等方法時,不是在原Sting對象的基礎上改變對象內容,而是創建了一個新的String對象把調用的方法後返回的結果放在這個新的String對象中 代碼示例如下: String str3 = " ...
  • ... ...
  • 為什麼需要線程同步? 同步就是協同步調,按預定的先後次序進行運行。如:你說完,我再說而並非一起動作。“同”字應是指協同、協助、互相配合。 如進程、線程同步,可理解為進程或線程A和B一塊配合,A執行到一定程度時要依靠B的某個結果,於是停下來,示意B運行;B依言執行,再將結果給A;A再繼續操作。 所謂同 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...