JVM工具使用和Linux-top命令解析
top 命令
top 命令查看现在线程占用资料的情况。
第三行,cpu状态信息,具体属性说明如下: us — 用户空间占用CPU的百分比。(重要) sy — 内核空间占用CPU的百分比。 ni — 改变过优先级的进程占用CPU的百分比 id — 空闲CPU百分比 wa — IO等待占用CPU的百分比 hi — 硬中断(Hardware IRQ)占用CPU的百分比 si — 软中断(Software Interrupts)占用CPU的百分比
下面的表示各个线程占用资源的情况,
PID 进程id USER 进程所有者 PR 进程优先级 NI nice值。负值表示高优先级,正值表示低优先级 VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES RES 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA SHR 共享内存大小,单位kb S 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程 %CPU 上次更新到现在的CPU时间占用百分比 %MEM 进程使用的物理内存百分比 (重要) TIME+ 进程使用的CPU时间总计,单位1/100秒 COMMAND 进程名称(命令名/命令行)
比如我要查看 java 相关的所有线程占用情况
top -H -p 24334
使用 jstack 命令打印堆栈工具
jstack是JDK内置的堆栈跟踪工具
jstack 24334 > jstack.txt
(6902是Java进程的PID)打印出了Java进程的堆栈信息放到jstack.txt文件了;由于堆栈打印的线程的native id是十六机制的,所以,我把十进制的线程 24340转化成十六进制 5f14
最后,通过
cat jstack.txt | grep -C 20 5f14
jstat 怼内存使用情况
jstat是JDK内置的JVM检测统计工具,可以对** 堆内存的使用情况进行实时统计** 。
上面数值的含义和JVM的参数一一对应
E : Eden区 O : Old区 FGC : Full GC 次数,例子中共 4 次 FGCT : Full GC 的时间,例子共0.2秒左右
这个工具对于查内存泄漏非常有用。这里引用参考资料中的一个内存泄漏例子 :
E(Eden区)跟O(Old区)的内存已经被耗尽了,FGC(Full GC)的次数高达6989次,FGCT(Full GC Time)的时间高达36453秒,即平均每次FGC的时间为:36453/6989 ≈ 5.21秒。也就是说,Java进程都把时间花在GC上了,所以就没有时间来处理其他事情。
jmap 获取进程的内存映射信息
假如真的出现了内存泄漏,那么一定要知道对应的代码在哪里才可以解决问题,就要使用 jmap 工具查出某个线程中内存个映射的对象是哪些。
jmap -histo 24334|less
其中 |less
表示打印的页数慢慢显示而不是一下子刷到最底下。
实例的数量和字节数量,这样就可以进行分析了。
jmap -histo 24334|less|grep sun
其中|grep sun
则是进行一个筛选,这个命令加在其他命令后面也一样,可以使用。
参考资料
https://blog.csdn.net/liubin1991liubin/article/details/79702640 https://segmentfault.com/q/1010000003586656