面試常被問到的 JDK 命令,你知道幾個?
Hello 大家好,我是鴨血粉絲,不知道你有沒有過這樣的經(jīng)歷,經(jīng)常在面試的時候被問到 JDK 相關的命令,如何排查線上的問題,線上程序突然崩了要怎么處理,等等類似這種場景。其實并不是每個開發(fā)人員都能有這種實戰(zhàn)經(jīng)驗,現(xiàn)實工作中往往很多開發(fā)人員是接觸不到線上環(huán)境的。但是作為一個以 Java 謀生的程序員,如果連這些 JDK 自帶的一些命令都不知道,那也說不過去。
阿粉以前也是這樣,從來沒有接觸過線上環(huán)境,有任何問題都是運維人員去處理,因為相關制度不允許開發(fā)人員接觸生產(chǎn)服務器。但是作為一個有夢想的開發(fā)人員,不能接觸不代表就不用學,阿粉還是私下好好學習了一波,萬一哪天就用上了呢。
JDK 常用命令
先給大家看一張總覽圖,然后我們一個個命令去使用一下,感受一下。
JPS
說明:首先通過上圖,我們看到使用 jps 或者 jps | grep -v Jps 命令的時候是可以找到當前系統(tǒng)所有JVM。上面第二條命令是過濾本身的 Jps 程序??梢钥吹?,輸入這個命令后,會展示出當前系統(tǒng)所有的 Java 程序,并且會輸出進程號 pid(也就是前面的數(shù)字)。
我們通過命令 man jps 簡單的看下說明,如下:
可以看到 jps 命令有五個參數(shù),每個參數(shù)的含義如下,
- -q: 不輸出類名信息和參數(shù),只輸出進程號
- -m:展示輸入到 main 方法的參數(shù)
- -l:展示 main class 全路徑
- -v:展示輸入 JVM 的參數(shù)
- -V:不輸出路徑,只輸出進程號和jar
我們依次輸入試下,如下圖
Jinfo
通過上一步我們可以獲得對應 JVM 的進程號,這為我們后續(xù)的操作提供了便利,后續(xù)的操作都會使用到進程號。
我們先使用一下命令,在使用前我們先獲取進程號,我這里服務器運行的進程號為 2528,然后輸入jinof 2528
通過上圖,我們看到當前 JVM 的版本以及其他詳細信息,并且可以看到服務器以及環(huán)境變量等一系列信息。同樣的我們使用 man jinfo 命令看下手冊。
該命令主要是用戶查看當前虛擬機相關信息,我們就不過多介紹了。
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 -h3 2528 1000 10,最后的效果會是下圖,我們可以看到每三行就增加了一個表頭,更多命令大家可以自己試試。
Jmap
jmap 命令用于生成dump 文件,jmap -dump:live,format=b,file=dump.bin 2528創(chuàng)建 dump 文件如下。
通過jmap 命令我們可以生成內存快照文件,用于分析程序異常時的內存信息,并且配合 jhat命令可以更好的使用。
Jhat
上面提到我們在使用 jmap 的時候生成了一個內存快照文件,那我們如何查看這個內存文件呢?這里就需要結合jhat命令了。我們使用jhat dump.bin 就可以啟動一個服務,然后通過瀏覽器打開默認的 7000 端口來查看信息。
訪問 7000 端口如下:
Jstack
jstack用于生成java虛擬機當前時刻的線程快照,線程快照是當前 java 虛擬機內每一條線程正在執(zhí)行的方法堆棧的集合,生成線程快照的主要目的是定位線程出現(xiàn)長時間停頓的原因,如線程間死鎖、死循環(huán)、請求外部資源導致的長時間等待等。線程出現(xiàn)停頓的時候通過 jstack來查看各個線程的調用堆棧,就可以知道沒有響應的線程到底在后臺做什么事情,或者等待什么資源。
使用命令jstack 2528 查看線程堆棧情況如下:
通過這個命令我們可以看到進程對應的線程執(zhí)行情況,可以分析哪些線程在允許,哪些線程在等待。
總結
JDK 常見的命令阿粉就給大家介紹到這里,在平時的工作和學習中大家可以嘗試去使用一下,感受一下,這樣就算是在面試的時候或者實際要用的時候就能做的得心應手。