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