首页 > 编程语言 > 详细

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

时间:2018-03-31 15:40:05      阅读:211      评论:0      收藏:0      [点我收藏+]

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 二进制的号

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

原文:https://www.cnblogs.com/wghzzu/p/8682309.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!