转载:javacore文件及heapdump文件分析
来源:互联网 发布:取消映射网络驱动器 编辑:程序博客网 时间:2024/06/09 23:40
转载自:http://blog.csdn.net/jjyyaa007/article/details/5323899
Java程序运行时,有时会产生javacore及heapdump文件,为什么会产生这些文件呢?产生后应该如何分析呢?本文将回答上面的问题。
java程序在遇到致命问题时,就会产生这两个文件,有时产生时,java应用不会死掉,还能继续运行,有时则java进程会死掉,即java进程被杀死。为了能够保留java应用发生致命错误前的java的运行状态,jvm在死掉前产生两个文件,分别为javacore及heapdump文件。
javacore文件主要保存的是java应用各线程在某一时刻的运行的位置,即执行到哪一个类的哪一个方法哪一个行上。javacore是一个文本文件,打开后可以看到每一个线程的执行栈,以stacktrace的方式显示。通过对javacore的分析可以得到应用是否“卡”在某一点上,即在某一点运行的时间太长,如数据库查询,长期得不到响应,最终导致系统崩溃。
heapdump文件是一个二进制文件,它保存了某一时刻jvm堆中对象情况,这种文件需要相应的工具进行分析,笔者用得较多的是heap analyzer这个工具。这个文件最重要的作用就是分析系统是否存在内存溢出的情况,通过heapanalyzer可以很简单地分析出溢出的位置。
这两个文件也可以手工的方式生成,经常我们会遇到系统变慢或无响应的情况,这个时候就以采用手工的方式生成javacore及heapdump文件,通过对这两个文件的分析,查出原因进而解决问题,在unix/Linux上,产生这两个文件的方法是首先,ps -ef|grep java 找出java进程id ,然后再执行kill -3 进程号 的操作,等文件生成后再做一次同样的操作,再产生一组文件,两组文件在分析javacore时特别有效,困为它可以看出在先后两个时间点上,线程执行的位置,如果发现先后两组数据中同一线程都执行在同一位置,则说明此处可能有问题,因为程序运行是极快的,如果两次均在某一点上,说明这一点耗时是很大的。
- 转载:javacore文件及heapdump文件分析
- javacore文件及heapdump文件分析
- javacore文件及heapdump文件分析
- javacore文件及heapdump文件分析
- javacore文件及heapdump文件分析
- Heapdump javacore文件分析工具
- Heapdump javacore文件分析工具
- Heapdump javacore文件分析工具
- JavaCore/HeapDump文件分析工具
- JavaCore/HeapDump文件分析工具
- JavaCore/HeapDump文件分析工具
- 每日一得--java异常javacore文件及heapdump文件分析
- JavaCore/HeapDump文件及其分析方法
- JavaCore/HeapDump文件及其分析方法
- JavaCore/HeapDump文件及其分析方法
- 2.JavaCore/HeapDump文件及其分析方法
- JavaCore/HeapDump文件及其分析方法
- JavaCore/HeapDump文件及其分析方法
- thinkphp如何实现伪静态
- UltraEdit注册机 及使用方法详解
- eclipse+android如何设置代码自动提示功能
- C++—chapter1
- AndroidStudio导入SlidingMenu
- 转载:javacore文件及heapdump文件分析
- Eclipse使用技巧总结
- NLP:词性标准
- React Native系列(一)React Native 环境搭建
- C++ 函数作用域
- [笔记] Gitlab手术室:LDAP配置好却一直Invalid Credential的解决
- NOIP2013 积木大赛 解题报告(贪心)
- Qt 在VS下使用添加新类后报错LNK2019无法解析的外部符号解决办法
- visual studio 2015怎么下载