当前位置:   article > 正文

linux java内存查看工具_linux 下使用命令查看jvm信息

linux查看jvm内存占用的工具

java程序员除了编写业务代码之外,特别是项目上线之后,更需要关注的是系统的性能表现,这个时候就需要了解一下jvm的性能表现了,可以借助于java虚拟机自带的一些分析工具,主要有三个常用的命令。

1. jmap

这个命令是用来查看当前系统中jvm进程 heap dump的情况,包括对象的数量,对象所占内存的大小

使用方式:先使用jps查看进程id

83b731cf24a4e2140f47dbef48128d34.png

使用 jmap -dump:live,file=b.map 22467 将live进程生成java堆转储快照

e9b76837413ef903913f160360fc9844.png

使用 jmap -heap PID 生成java堆的详细信息

使用 jmap -histo PID 生成java堆中对象的相关信息,包含数量以及占用的空间大小

fbba4d04e9aaf4b2113a80c842eb57c3.png

2. jstat

主要是用来监控 heap size 和 jvm垃圾回收情况,尤其是gc情况的监控,如果老年代发生full gc,那么很可能会导致内存泄漏的可能性

60f6a381aa0e8d2ba6a6ca9749290f65.png

可以看到新生代survivor S0, survivor S1 heap上的空间 使用百分比,堆中新生代Eden 的空间使用百分比,老年代Old 空间的使用百分比,内存的使用百分比,新生代Yong gc 的统计次数,新生代gc 花费的时间,full gc 的次数,花费的时间,当前进程总的gc时间,这里要注意一点,full gc很具有代表性,full gc次数 和时间 指标很能显示系统性能问题,这两个指标很大,很大程度上说明了程序中有问题,垃圾一直回收不掉

3. jstack

先使用 top 查看系统中消耗cpu比较多的进程,然后使用 top -p PID -H来查看当前进程中比较消耗cpu的线程,拿到消耗cpu比较高的线程pid,先转换成16进制的,最后使用jstack pid|grep 16进制的线程id

9b75b53765bce2cb73890a7512c9eed9.png

jstack -pid可以用来分析进程情况

6a4c9621de758658691c44b95896f35f.png

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/554167
推荐阅读
相关标签
  

闽ICP备14008679号