java core 分析_JavaCore文件分析 | 學步園

  • Post author:
  • Post category:java


產生時間

Java程序運行時,有時會產生JavaCore及HeapDump文件,它一般發生於Java程序遇到致命問題的情況下。

有時致命問題發生後,Java應用不會死掉,還能繼續運行;

但有時致命問題發生,Java進程會死掉;

為了能夠保留Java應用發生致命錯誤前的運行狀態,JVM在死掉前產生兩個文件,分別為JavaCore及HeapDump文件。

有何區別

JavaCore是關於CPU的,而HeapDump文件是關於內存的。

JavaCore文件主要保存的是Java應用各線程在某一時刻的運行的位置,即JVM執行到哪一個類、哪一個方法、哪一個行上。它是一個文本文件,打開後可以看到每一個線程的執行棧,以stack trace的顯示。通過對JavaCore文件的分析可以得到應用是否“卡”在某一點上,即在某一點運行的時間太長,例如數據庫查詢,長期得不到響應,最終導致系統崩潰等情況。

HeapDump文件是一個二進制文件,它保存了某一時刻JVM堆中對象使用情況,這種文件需要相應的工具進行分析,如IBM Heap

Analyzer這類工具。這類文件最重要的作用就是分析系統中是否存在內存溢出的情況。

怎麼生成

這兩個文件可以用手工的方式生成,當我們會遇到系統變慢或無響應的情況,這時就以採用手工的方式生成JavaCore及HeapDump文件。

在Unix/Linux上,產生這兩個文件的方法如下:

# ps -ef | grep java

user46164582017:30pts/000:00:00grep java



版权声明:本文为weixin_32491255原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。