第七章 JVM性能監控與故障處理工具(1)

来源:http://www.cnblogs.com/java-zhao/archive/2016/02/07/5184485.html
-Advertisement-
Play Games

1、定位系統問題 依據 GC日誌 堆轉儲快照(heapdump/hprof文件) 線程快照(threaddump/javacore文件) 運行日誌 異常堆棧 分析依據的工具 jps:顯示指定系統內的所有JVM進程 jstat:收集JVM各方面的運行數據 jinfo:顯示JVM配置信息 jmap:形成


1、定位系統問題

  • 依據
    • GC日誌
    • 堆轉儲快照(heapdump/hprof文件)
    • 線程快照(threaddump/javacore文件)
    • 運行日誌
    • 異常堆棧
  • 分析依據的工具
    • jps:顯示指定系統內的所有JVM進程
    • jstat:收集JVM各方面的運行數據
    • jinfo:顯示JVM配置信息
    • jmap:形成堆轉儲快照(heapdump文件)
    • jhat:分析heapdump文件
    • jstack:顯示JVM的線程快照
    • jconsole
    • visualVM

說明:後邊兩種是具有圖形化界面的。

 

2、jps(是其他所有命令的基礎)

作用:列出所有的JVM虛擬機進程。

格式:jps -l

 

3、jstat(是沒有GUI界面的情況下,在運行期定位JVM性能問題的首選

作用:查看gc數據和類載入卸載數據

格式:jstat option PID interval count

意義:每隔interval毫秒做一次option,一共做count次

說明:S0(from區)使用了41.74%;S1(to區)使用了0;E(Eden區)使用了54.35%;O(Old,年老代)使用了62.41%;P(Perment,永久代)使用了99.63%;YGC(Young GC)了32次,YGCT(Young GC Time)花銷0.132秒;FGC(Full GC)了1次,FGCT(Full GC Time)花銷0.102秒;GCT(GC Time)總花銷0.234秒。

分析:其實上邊這個查詢結果可以直接看出,我們需要加大P(永久代大小)

說明:載入了3683個類,總共占有4355.3位元組;卸載了0個類,卸載的類的位元組數為0,類的載入與卸載共花銷3.16秒

更多的jstat的使用,參看http://my.oschina.net/skyline520/blog/304805

 

4、jinfo

作用:查看和運行期修改JVM的配置參數

格式:jinfo -flag parameter PID

說明:查看3732進程下的MaxTenuringThreshold參數值。

說明:修改3732進程下的MaxTenuringThreshold參數值,但是windows下失敗。

 

5、jmap

作用:生成堆轉儲快照和查看最占記憶體的元素,用於分析記憶體泄露問題

格式(生成堆轉儲快照):jmap -dump:format=b,file=文件名 PID

說明:生成了3732進程的堆轉儲文件myfile

格式(查看最占記憶體的元素):jmap -histo PID

說明:結果自己去看,太多了

 

6、jhat

作用:分析堆轉儲快照(與jmap配合)

格式:jhat 文件名

說明:執行上述命令後,打開localhost:7000,找到如下紅框部分打開,這裡才是我們最關註的東西

註意:該工具是萬不得已才用的。

推出命令使用"ctrl+c"

 

7、jstack

作用:生成線程快照,定位線程長時間卡頓的原因(線程間死鎖、死迴圈、請求外部資源導致的長時間等待)

格式:jstack -l PID

說明:查看3732進程中的所有線程的堆棧信息

《深入理解Java虛擬機》的作者提供了一個工具jsp頁面,使得我們可以在程式運行時,隨時運行該jsp頁面,來查看線程堆棧信息,代碼如下:

 1 <%@ page language="java" contentType="text/html; charset=UTF-8"
 2     pageEncoding="UTF-8" import="java.util.Map"%>
 3 <!DOCTYPE html>
 4 <html>
 5 <head>
 6 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 7 <title>jstack</title>
 8 </head>
 9 <body>
10 <% 
11     for(Map.Entry<Thread, StackTraceElement[]> stackTrace : Thread.getAllStackTraces().entrySet()){
12         Thread thread = (Thread)stackTrace.getKey();
13         StackTraceElement[] elements = (StackTraceElement[])stackTrace.getValue();
14         
15         /* if(thread.equals(Thread.currentThread())){
16             continue;
17         } */
18         out.println("\n線程:"+thread.getName()+"\n");
19         for(StackTraceElement ele : elements){
20             out.println("\t"+ele+"\n");
21         }
22     }
23 %>
24 </body>
25 </html>
View Code

註意:代碼中我註釋掉一段,是因為想也查出當前線程的堆棧信息,作者並沒有這個註釋。

 

總結:

  • JVM性能相關的6個常用的JDK命令
    • jps:查詢JVM中的所有進程,找出將要操作的PID,是所有命令的基礎
    • jstat:查看相應JVM進程的gc、類載入卸載信息,是沒有GUI界面查看JVM運行數據的首選
    • jinfo:查看和在運行期動態修改JVM配置參數
    • jmap:生成堆轉儲快照和比較占記憶體的對象
    • jhat:配合jmap分析堆轉儲日誌,除非沒有其他工具可做這個事兒,否則就不用該工具
    • jstack:生成線程快照,定位線程長時間卡頓的原因(線程間死鎖、死迴圈、請求外部資源導致的長時間等待)
  • 輸出gc信息到控制台
    • -XX:+PrintGCDetails:輸出GC的詳細信息
    • -XX:+PrintGCTimeStamps:輸出GC的時間信息
    • -XX:+PrintGCApplicatonStoppedTime:GC造成的應用暫停的時間
  • 輸出gc信息到文件
    • 以上三個參數在這裡依舊適用
    • -Xloggc:文件路徑/gc.log:輸出到文件

 


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

-Advertisement-
Play Games
更多相關文章
  • 如果沒記錯的話,阿裡雲ECS上的Ubuntu也是LTS版本。 如果還在使用較舊版本的Ubuntu,或者是Ubuntu LTS,那麼我們是很難體驗新版gcc的。怎麼辦呢? 我們或許可以自己去編譯用舊版本的gcc去編譯新版本,但比較繁瑣而且坑點較多。如果有現成的包就好啦! 原來,在toolchain/t
  • 丙申年把真假美猴王囚禁在容器中跑 ASP.NET Core 1.0¶警告您當前查看的頁面是未經授權的轉載! 如果當前版本排版錯誤,請前往查看最新版本:http://www.cnblogs.com/qin-nz/p/aspnetcore-run-on-mono-in-year-of-monkey.ht...
  • 之前就是說過“一個項目有很多重要的步驟以及功能”,那我們現在就來看看對於KTV項目來說;後臺是處於什麼樣的重要作用! 首先就得瞭解KTV後臺的一些功能了: 1.歌曲管理 、歌手管理 、設置資源路徑 2.新增歌手、歌手查詢、新增歌曲、歌曲查詢、更改歌曲路徑以及退出點歌系統 一.後臺登錄界面 01.判斷
  • continue和break可以改變迴圈的執行流程,但在多重迴圈中,這兩條語句無法直接從內層迴圈跳轉到外層迴圈。在C語言中,可以通過goto語句實現多重迴圈的跳轉,但在非迴圈結構中使用goto語句會使程式的結構紊亂,可讀性變差。因此Java就發明瞭一種帶標簽的continue和break語句,實際上...
  • 數據類型內置函數用法int 關於內置方法是非常的多這裡呢做了一下總結 (1)__abs__(...)返回x的絕對值 #返回x的絕對值!!!都是雙下劃線 x.__abs__() <==> abs(x) 例如: #!/usr/bin/python print "abs(-45) : ", abs(-45
  • pycharm開發django工程(二) 項目需求: 1. 從mongodb中讀取數據,並顯示到網頁中 2. 在網頁顯示的每一頁加入分頁符 首先使用pycharm的企業版新建一個django的虛擬工程(參考我的上一個博客),這是初始的顯示效果 這是原始的html文件,css文件在本文的最後,至於圖片...
  • 1.continue 語句的作用 終止本次迴圈的執行,即跳過當前一次迴圈中continue語句後尚未執行的語句,然後進行下一次迴圈條件的判斷。 2.break 語句的作用 (1)當break在迴圈體內時,強行終止整個迴圈的執行,即結束整個迴圈過程,不再判斷執行迴圈的條件是否成立,直接轉向迴圈體下麵的
  • 《微型電腦原理與介面技術(第2版)》馮博琴 吳寧 主編-清華大學出版社——做筆記用 一、8088/8086的14個16位寄存器: //----------------------------------------------------------------------------------
一周排行
    -Advertisement-
    Play Games
  • 基於.NET Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...