lotus

贵有恒何必三更眠五更起 最无益只怕一日曝十日寒

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
  1846 随笔 :: 0 文章 :: 109 评论 :: 288万 阅读

 

很多情况下,都会出现dump这个字眼,java虚拟机jvm中也不例外,其中主要包括内存dump、线程dump。

 

当发现应用内存溢出或长时间使用内存很高的情况下,通过内存dump进行分析可找到原因。

当发现cpu使用率很高时,通过线程dump定位具体哪个线程在做哪个工作占用了过多的资源。

 

首先,内存dump是指通过jmap -dump <pid>输出的文件,而线程dump是指通过jstack <pid>输出的信息。

两个dump可以单独使用,也可以在特定场合下结合使用。

 

在linux操作系统下(已安装jdk),执行jps命令,列出正在运行的java程序的进程ID。

 

使用top查看目前正在运行的进程使用系统资源情况。

 

其中进程号为24660的进程,jps输出列表和top列表中都出现,并且在top列表中显示是由java COMMAND启动的。

其中%MEM为2.9,说明占用系统内存为2.9%,当前系统大概8G内存;另外%CPU指的是当前进程使用CPU资源百分比;

 

【内存dump】

jmap –dump:live,format=b,file=heap.bin <pid>

参考资料:http://docs.oracle.com/javase/6/docs/technotes/tools/share/jmap.html

 

将生成的heap.bin文件,使用ha456.jar工具打开分析。java -jar -Xmx3000m ha456.jar

 

【线程dump】

jstack -m <pid> >jvm_deadlocks.txt

jstack -l <pid> >jvm_listlocks.txt

参考资料http://docs.oracle.com/javase/6/docs/technotes/tools/share/jstack.html

使用top -H -p <pid>找出某进程中要分析的线程ID,然后将线程ID转换为16进制后,在线程dump文件中搜索相关信息

posted on   白露~  阅读(3017)  评论(0编辑  收藏  举报
编辑推荐:
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示