java内存溢出排查jstack_Java命令行监控工具(jmap,jstack,jstat,jinfo,jps)
項目部署上線之后,線上項目是不能輕易修改的,定位問題的難度也會變大。因此監控是非常重要的一個環節,有了監控,我們才能更好的定位系統中的問題,從而排查。監控的工具有很多種, 但是java自帶的命令行監控工具,是必須要掌握的。
jps
查看系統中jvm進程, 其它的命令通常先使用jps查看進程號,然后在根據線程號獲取jvm進程信息
image.png
jps -m 查看jvm進程并且帶有參數查看
jps -v 查看傳遞到jvm的參數
jstat
顯示JVM的性能統計信息,
常見用法:jstat - [-t] [-h] [ []]
例如:查看JIT編譯信息,GC信息和JVM中的class信息。
image.png
解釋下-gc選項中列的含義:-gc查看垃圾收集器中的信息, 主要包含jvm的運行時數據區統計。
后綴為C的代表當前區的容量,后綴為U的代表已經使用了多少容量,后綴為T的代表耗時
S0C 存活區0的容量(KB)
S1C 存活區1的容量(KB)
S0U 存活區0使用的空間 (KB).
S1U 存活區1的利用空間 (KB).
EC Eden區的容量(KB).
EU Eden區利用的容量(KB).
OC 老年代容量(KB).
OU 老年代使用容量(KB).
PC 當前永久帶的容量(KB).
PU 永久帶使用容量(KB).
YGC 發生了多少次Young GC
YGCT Young GC的時間
FGC Full GC的次數
FGCT Full GC的收集時間
GCT 總共的GC時間.
jstack
查看線程堆棧信息,在發生死鎖的時候可以利用這個命令查找死鎖或者在發生死循環的時候利用此命令排查。
jstack vmpid 會打印線程的堆棧信息。通過堆棧可以查看具體線程正在執行那些代碼,廈門演示兩個使用jstack排查死鎖與死循環的命令。
死鎖代碼:
public class DeadLock {
private static Object o1 = new Object();
private static Object o2 = new Object();
private static CountDownLatch countDownLatch = new CountDownLatch(2);
public static void main(String[] args) throws InterruptedException {
new Thread(){
@Override
public void run() {
synchronized (o1){
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("線程1 獲得鎖1");
synchronized (o2){
System.out.println("線程1 獲得鎖2");
countDownLatch.countDown();
}
}
}
}.start();
new Thread(){
@Override
public void run() {
synchronized (o2){
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("線程2 獲得鎖2");
synchronized (o1){
System.out.println("線程2 獲得鎖1");
countDownLatch.countDown();
}
}
}
}.start();
countDownLatch.await();
System.out.println("執行完畢");
}
}
死鎖之后:
可以看到jstack已經幫我們找到了死鎖。
image.png
image.png
死循環需要配合Top命令一起使用,死循環會導致CPU不斷的飆升,這時候使用top命令,查看cpu占用率較高的命令:
image.png
使用top -H -p 24278 查看進程中具體是那一條線程的CPU利用率高
image.png
可以看到是24279的線程,在top中使用的是10進制,在jstack中打印的線程是16進制,因此做一次轉換。
24279 => 5ed7
然后查看線程:
image.png
然后我們可以知道具體那一行的指令在一直運行。
jinfo查看JVM啟動時候設置的參數值
jinfo可以查看當前JVM線程配置的系統屬性,以及運行時設置的參數值。
直接使用jinfo
前半段是系統的屬性
image.png
后半段是jvm的參數
image.png
我們也可以直接使用jinfo查看具體的某個參數值:
image.png
jmap分析堆
在發生OME的時候,會用jmap分析堆中具體是什么問題,才能更好的解決問題。jmap一般和mat配合使用。
一般在java開發的項目啟動時候,最好加上下面命令,在內存溢出的時候可以通過日志查看信息。
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/java/dump
當然在項目運行的時候也可以使用jmap -heap jvmpid查看對象內存的映射。
演示內存溢出
堆內存溢出代碼
public class DealCycle {
public static LinkedList linkedList = new LinkedList<>();
public static void main(String[] args) {
int i = 0;
while (true){
linkedList.add(i);
}
}
}
運行:
image.png
大家可以去網站上下載java mat的二進制壓縮包,學習一下
image.png
image.png
如果每次都等到內存溢出才導出文件時間就有些晚了,可以使用jmap直接導出
image.png
最后
這篇文章主要介紹了java自帶的命令行工具,通過這些命令行工具,我們可以很好的得知當前jvm的運行狀態。
總結
以上是生活随笔為你收集整理的java内存溢出排查jstack_Java命令行监控工具(jmap,jstack,jstat,jinfo,jps)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java无向图代码实例_Java 图示例
- 下一篇: matebook14支持触摸屏吗_华为M