Linux 某个进程中占用CPU高的线程

1、通过top,找出占用CPU高的进程ID

2、

如上图所示,java的进程id为’52554′,接下来用top命令单独对这个进程中的所有线程作监视:

top-p52554 -H

3、如图:(这时就看出来哪个java线程CPU高,哪个线程内存用的多)

4、

如上图所示,linux下,所有的java内部线程,其实都对应了一个进程id,也就是说,linux上的sun jvm将java程序中的线程映射为了操作系统进程;我们看到,占用CPU资源最高的那个进程id是’15417′,这个进程id对应java线程信息中的’nid’(‘n’ stands for ‘native’);

5、要想找到到底是哪段具体的代码占用了如此多的资源,先使用jstack打出当前栈信息到一个文件里, 比如stack.log:

  1. jstack 52554 > stack.log
  2. python -c"print hex(9757)"然后记住二进制的号
  3. cat stack.log|grep 二进制的号

转载于:https://www.cnblogs.com/wghzzu/p/8682309.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值