第七章 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 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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...