java程序运行时,有时会产生javacore及heapdump文件,为何会产生这些文件呢?产生后应该如何分析呢?本文将回答上面的问题。java
java程序在遇到致命问题时,就会产生这两个文件,有时产生时,java应用不会死掉,还能继续运行,有时则java进程会死掉,即java进程被杀死。为了可以保留java应用发生致命错误前的java的运行状态,jvm在死掉前产生两个文件,分别为javacore及heapdump文件。linux
javacore文件主要保存的是java应用各线程在某一时刻的运行的位置,即执行到哪个类的哪个方法哪个行上。javacore是一个文本文件,打开后能够看到每个线程的执行栈,以stacktrace的方式显示。经过对javacore的分析能够获得应用是否“卡”在某一点上,即在某一点运行的时间太长,如数据库查询,长期得不到响应,最终致使系统崩溃。数据库
heapdump文件是一个二进制文件,它保存了某一时刻jvm堆中对象状况,这种文件须要相应的工具进行分析,笔者用得较多的是heap analyzer这个工具。这个文件最重要的做用就是分析系统是否存在内存溢出的状况,经过heapanalyzer能够很简单地分析出溢出的位置。jvm
这两个文件也能够手工的方式生成,常常咱们会遇到系统变慢或无响应的状况,这个时候就以采用手工的方式生成javacore及heapdump文件,经过对这两个文件的分析,查出缘由进而解决问题,在unix/linux上,产生这两个文件的方法是首先,ps -ef|grep java 找出java进程id ,而后再执行kill -3 进程号 的操做,等文件生成后再作一次一样的操做,再产生一组文件,两组文件在分析javacore时特别有效,困为它能够看出在前后两个时间点上,线程执行的位置,若是发现前后两组数据中同一线程都执行在同一位置,则说明此处可能有问题,由于程序运行是极快的,若是两次均在某一点上,说明这一点耗时是很大的。工具
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/jjyyaa007/archive/2010/02/25/5323899.aspx.net