Java虛擬機知識點【工具】

来源:https://www.cnblogs.com/bigshark/archive/2019/07/27/11253590.html
-Advertisement-
Play Games

命令行工具 1. jps JVM Process Status Tool,顯示虛擬機進程。 用法 : 參數說明 q:列印進程號 l:列印啟動類的全限定名 m:列印啟動類的 main 方法入參 v:列印指定的虛擬機參數 V:列印類名 例子 : 、`jps l` 2、jstat JVM statisti ...


命令行工具

1. jps

JVM Process Status Tool,顯示虛擬機進程。

用法jps [-q] [-mlvV]

參數說明

  • -q:列印進程號
  • -l:列印啟動類的全限定名
  • -m:列印啟動類的 main 方法入參
  • -v:列印指定的虛擬機參數
  • -V:列印類名

例子jpsjps -l

2、jstat

JVM statistics Monitoring,對Java虛擬機記憶體進行監控統計。

用法jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]

參數說明

  • option:操作,常用的就是gcutil,統計垃圾回收情況。
  • -t:顯示時間戳列
  • -h:指定多少行顯示標題
  • -vmid:進程ID
  • -interval:每行輸出的時間間隔
  • -count:指定輸出行數

例子jstat -gcutil -h2 -t 15754 100 5,表示監控進程號15754的垃圾收集統計值,每隔100ms輸出一行,總共輸出5次,每輸出2次需要重新輸出標題。

[root@root ~]# jstat -gcutil -h2 -t 15754 100 5
Timestamp         S0     S1     E      O      M     CCS    YGC     YGCT    FGC    FGCT     GCT   
     11296830.0   0.00 100.00  21.80  25.80  98.41  96.33 113648 2500.825     0    0.000 2500.825
     11296830.2   0.00 100.00  21.80  25.80  98.41  96.33 113648 2500.825     0    0.000 2500.825
Timestamp         S0     S1     E      O      M     CCS    YGC     YGCT    FGC    FGCT     GCT   
     11296830.3   0.00 100.00  21.80  25.80  98.41  96.33 113648 2500.825     0    0.000 2500.825
     11296830.4   0.00 100.00  21.80  25.80  98.41  96.33 113648 2500.825     0    0.000 2500.825
Timestamp         S0     S1     E      O      M     CCS    YGC     YGCT    FGC    FGCT     GCT   
     11296830.5   0.00 100.00  21.80  25.80  98.41  96.33 113648 2500.825     0    0.000 2500.825

輸出的指標說明

  • S0:survivor 0 已用空間占比
  • S1:survivor 1 已用空間占比
  • E:Eden 區已用空間占比
  • O:老年代已用空間占比
  • M:元數據已用空間占比
  • CCS:壓縮類空間占比
  • YGC:Mirror GC 次數
  • YGCT:Mirror GC 消耗時間
  • FGC:Full GC 次數
  • FGCT:Full GC 消耗時間
  • GCT:垃圾回收消耗總時間

3. jinfo

JVM Configuration info,可以實時查看和實時修改虛擬機參數。

用法jinfo [option] <pid>

參數說明

  • option:操作

    -flag 列印指定的VM參數的值
    -flag [+|-] 啟用或禁用指定的VM參數
    -flag = 修改VM參數
    -flags 列印VM參數
    -sysprops 列印Java系統配置

  • pid:進程ID

例子jinfo 15754jinfo -flags 15754

4. jmap

JVM Memory Map,用來生成堆棧dump文件。

用法jmap [option] <pid>

參數說明

  • option:操作

    heap:列印Java堆摘要
    histo[:live]:列印java對象堆的直方圖; 如果指定了“live”選項,則僅計算實時對象
    dump:生成dump快照

  • pid:進程ID

例子jmap -heap 15754jmap -histo:live 15754jmap -dump:live,file=.\heap_dump.hprof 15754

5. jstack

用來生成Java虛擬機當前時刻的線程快照,方便定位線程長時間停頓的問題,比如死鎖、死迴圈、長時間等待等。

用法jstack -F [-m] [-l] <pid>

參數說明

  • -F:強制列印堆棧
  • -m:同時列印Java和本地方法的堆棧
  • -l:列印關於鎖的附件信息
  • pid:進程ID

例子jstack -l 15754

6. jhat

JVM Heap Analysis Tool,用來分析jmap生成的堆棧日誌,生成HTML文件。一般會用可視化工具來分析堆棧日誌,比如MAT。

7. jcmd

JDK建議使用 jcmd 替代 jstack、jinfo、jmap 等命令。

例子

  • jcmd -l:列出所有Java虛擬機。
  • jcmd 15754 help:列出該虛擬機支持的命令。
  • jcmd 15754 PerfCounter.print:獲取所有性能相關的數據。
  • jcmd 15754 GC.class_histogram

可視化監控工具

常用的工具

  1. jconsole:JDK自帶監控工具
  2. jvisualvm:JDK自帶監控工具,比jconsole顯示更多監控數據
  3. jmc:也是JDK自帶監控工具,比jvisualvm顯示更多監控數據
  4. MAT:Memory Analyzer Tool,Java虛擬機記憶體分析工具,能夠快速的分析dump日誌。

參考資料:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html


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

-Advertisement-
Play Games
更多相關文章
  • html: <section> <nav id="nav"> <a class="on">tab1</a> <a>tab2</a> <a>tab3</a> <a>tab4</a> </nav> <div id="contentBox"> <div class="box active">內容一</di ...
  • 一、使用vue-cli搭建項目 註意:在mac執行該命令會報錯 改用管理員許可權執行以下命令即可 $ sudo npm install -g vue-cli$ vue init webpack tcloud$ cd tcloud$ npm run dev 完成了利用腳手架創建並啟動一個vue的項目,可 ...
  • 1 try catch的使用,永遠應該放在你的控制範圍之內,而不應該防範未知的錯誤。也就是說你很清楚知道這裡是有可能”出錯“的,而且你很清楚知道什麼前提下會出錯,你就是要故意利用報錯信息來區分錯誤,後續的程式會解決所有的出錯,讓程式繼續執行。如果讓用戶先發現你根本沒預料到的錯誤,而不是你先發現錯誤, ...
  • 在設計網站的過程中你們註意到banner和導航欄嗎?瞭解它們的用途可以更快更好的進行網站建設。經常瀏覽網頁的朋友們可能都會註意到,當打開一個網頁的時候最先映入眼帘的是個人企業logo和banner等。Banner的作用相當於市場上拉的橫幅,優秀的banner讓人一眼看出宣傳主題,也能鮮明的表達情感思 ...
  • 由於跨域策略,從另一個域請求文件可能會導致問題。從另一個域請求外部腳本沒有此問題。JSONP使用此優勢,並使用腳本標記而不是XMLHttpRequest對象請求文件。 ...
  • 流量紅利正逐漸走向終結,這已經不再是什麼秘密。後互聯網時代,如何維繫住用戶群,提升用戶在平臺上的體驗是整個行業都需要考慮的事情。正是出於這一原因,現在全行業都在關註會員體系的搭建,這也是馬蜂窩 2019 年重點投入的方向之一。 面對這個全行業都在發力的會員市場,要對「馬蜂窩特色」的會員體系進行有力的 ...
  • 分散式鎖 為什麼需要有分散式鎖呢,在單點的時候synchronized 就能解決,但是服務拆分之後,每個服務都是單獨的機器,無法解決,所以出現了分散式鎖,其實也就是用各種手段,實現獲取唯一鎖,別人無法得到。 其實在做分散式鎖的前提,需要先明白,synchronized 為啥不能使用了,啥原理讓他在一 ...
  • 智能家居-1.基於esp8266的語音控制系統(開篇) 智能家居-2.基於esp8266的語音控制系統(硬體篇) 智能家居-3.基於esp8266的語音控制系統(軟體篇) 樹莓派安裝及配置 鏡像文件下載地址 https://www.raspberrypi.org/downloads/ 安裝apach ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...