您好,登錄后才能下訂單哦!
本篇內容主要講解“JDK常用的命令有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“JDK常用的命令有哪些”吧!
JDK 常用命令
先給大家看一張總覽圖,然后我們一個個命令去使用一下,感受一下。
JPS
說明:首先通過上圖,我們看到使用 jps 或者 jps | grep -v Jps 命令的時候是可以找到當前系統所有JVM。上面第二條命令是過濾本身的 Jps 程序。可以看到,輸入這個命令后,會展示出當前系統所有的 Java 程序,并且會輸出進程號 pid(也就是前面的數字)。
我們通過命令 man jps 簡單的看下說明,如下:
可以看到 jps 命令有五個參數,每個參數的含義如下,
-q: 不輸出類名信息和參數,只輸出進程號
-m:展示輸入到 main 方法的參數
-l:展示 main class 全路徑
-v:展示輸入 JVM 的參數
-V:不輸出路徑,只輸出進程號和jar
我們依次輸入試下,如下圖
Jinfo
通過上一步我們可以獲得對應 JVM 的進程號,這為我們后續的操作提供了便利,后續的操作都會使用到進程號。
我們先使用一下命令,在使用前我們先獲取進程號,我這里服務器運行的進程號為 2528,然后輸入jinof 2528
通過上圖,我們看到當前 JVM 的版本以及其他詳細信息,并且可以看到服務器以及環境變量等一系列信息。同樣的我們使用 man jinfo 命令看下手冊。
該命令主要是用戶查看當前虛擬機相關信息,我們就不過多介紹了。
Jstat
jstat命令主要是用來監控虛擬機的狀態的,可以查看虛擬機 GC 的情況,如下命令jstat -gcutil 2528 1000 10表示每 1000 毫秒輸出一次進程 2528 的 GC 情況,并且總共輸出 10 次。
jstat 的手冊比較長,大家感興趣可以自行去查看下,這里只貼上面一部分給大家看下。
上面執行的jstat -gcutil 2528 1000 10 如果修改成這個jstat -gcutil -h4 2528 1000 10,最后的效果會是下圖,我們可以看到每三行就增加了一個表頭,更多命令大家可以自己試試。
Jmap
jmap 命令用于生成dump 文件,jmap -dump:live,format=b,file=dump.bin 2528創建 dump 文件如下。
通過jmap 命令我們可以生成內存快照文件,用于分析程序異常時的內存信息,并且配合 jhat命令可以更好的使用。
Jhat
上面提到我們在使用 jmap 的時候生成了一個內存快照文件,那我們如何查看這個內存文件呢?這里就需要結合jhat命令了。我們使用jhat dump.bin 就可以啟動一個服務,然后通過瀏覽器打開默認的 7000 端口來查看信息。
訪問 7000 端口如下:
Jstack
jstack用于生成java虛擬機當前時刻的線程快照,線程快照是當前 java 虛擬機內每一條線程正在執行的方法堆棧的集合,生成線程快照的主要目的是定位線程出現長時間停頓的原因,如線程間死鎖、死循環、請求外部資源導致的長時間等待等。線程出現停頓的時候通過 jstack來查看各個線程的調用堆棧,就可以知道沒有響應的線程到底在后臺做什么事情,或者等待什么資源。
使用命令jstack 2528 查看線程堆棧情況如下:
通過這個命令我們可以看到進程對應的線程執行情況,可以分析哪些線程在允許,哪些線程在等待。
到此,相信大家對“JDK常用的命令有哪些”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。