java堆内存jstat_Jvm dump jstack jmap jstat 介绍与使用(内存与线程) 以及使用jstack定位问题...

这个问题阿里经常问,参考:阿里面试

结论:

(1)栈信息:jstack 输出的信息。

(2)堆信息:jmap -dump 输出的文件,

(3)jstat查看gc情况,jstat -gc  间隔毫秒数 比如  jstat -gc 12345 5000  也就是每隔5秒打印进程12345的 gc情况

一、看一下 jstack

jstack -m >jvm_deadlocks.txt   jstack -l >jvm_listlocks.txt   参考资料 jstack - Stack Trace

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

首先看一下我自己在项目中使用 jstack如何查询问题:

可以使用jstat查看 gc情况  jstat -gc  12345  5000 (jstat -gc 进程号  间隔毫秒数)

定位问题

(1) 首先 找到相应的进程 使用 ps -ef | grep 'com.sankuai.qcs.regulation.dispatch'

找到进程的ID;==>21980

(2) top -Hp 21980(查询耗时最高的线程),发现有个线程确实不正常;

(3)jstack 21980 |grep '线程的16进制的ID'

注意 在第二步查到线程的ID之后,转换成16进制的。放在(3)里面;

同事查的:

进入系统 使用 grep -n 'java.lang.Thread.State:BLOCKED' jstack.log -A5;

查询:

Java通过jvm自己管理内存,同时Java提供了一些命令行工具,用于查看内存使用情况。

这里主要介绍一下jstat、jmap命令以及相关工具。

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

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

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

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

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

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

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

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

其中%MEM

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值