在项目运维过程中,难免会遇到一些问题需要获取一些环境中的真实JVM情况,这时会用到的就是jstack和jmap命令,今天就来整理下这两个命令的作用。
jstack | jmap | |
分析目标 | 线程 | 堆 |
作用 | 分析定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等问题 | 生成Java Heap Dump文件,以及查看Java进程中的内存使用情况,用它可以获得core文件的java stack和native stack的信息,从而知道Java程序是如何崩溃和在程序何处发生问题 |
使用 | jstack JAVA程序进程id > fileName.txt | jmap -dump:live,format=b,file=/path/to/heapdump.hprof JAVA程序进程id |
分析工具 | 可以使用JAVA自带的 VisualVM | 可以使用JAVA自带的 VisualVM |
生成文件 | 可能生成文件会很大,要注意硬盘空间 | 可能生成文件会很大,要注意硬盘空间 |
对程序影响 | 生成线程堆栈转储可能会对应用程序的性能产生短暂的影响,特别是在高负载的情况下。尽量在负载较低的时候进行此操作 | 生成堆转储可能会对应用程序的性能产生一定的影响,因此在生产环境中进行此操作时应该谨慎 |