java:找出占用CPU资源最多的那个线程(HOW TO)

在这里对linux下、sun(oracle) JDK的线程资源占用问题的查找步骤做一个小结;linux环境下,当发现java进程占用CPU资源很高,且又要想更进一步查出哪一个java线程占用了CPU资源时,按照以下步骤进行查找:

  1. 先用top命令找出占用资源厉害的java进程id,如:
  2. 如上图所示,java的进程id为‘12377‘,接下来用top命令单独对这个进程中的所有线程作监视:

    ?


    1

    top -p 12377 -H

    如图:

  3. 如上图所示,linux下,所有的java内部线程,其实都对应了一个进程id,也就是说,linux上的sun
    jvm将java程序中的线程映射为了操作系统进程;我们看到,占用CPU资源最高的那个进程id是‘15417‘,这个进程id对应java线程信息中
    的‘nid‘(‘n‘ stands for ‘native‘);
  4. 要想找到到底是哪段具体的代码占用了如此多的资源,先使用jstack打出当前栈信息到一个文件里, 比如stack.log:

    ?


    1

    jstack 12377 > stack.log

    然后使用‘jtgrep‘脚本把这个进程号为‘15417‘的java线程在stack.log中抓出来:

    ?


    1

    jtgrep 15417 stack.log

其中,‘jtgrep‘是自己随便写的一个shell脚本:

?


1

2

3

4

#!/bin/sh

nid=`python -c "print hex($1)"`

grep -i $nid $2

道理很简单,就是把‘15417‘转换成16进制后,直接grep stack.log;可以看到,被grep出的那个线程的nid=0x3c39,正好是15417的16进制表示。

文章出处:http://wenyue.me/blog/382

时间: 2024-10-15 10:16:04

java:找出占用CPU资源最多的那个线程(HOW TO)的相关文章

在LIUNX服务器上找出web项目中占用cpu资源最多的线程的排查方法

在这里对linux下.sun(oracle) JDK的线程资源占用问题的查找步骤做一个小结:linux环境下,当发现java进程占用CPU资源很高,且又要想更进一步查出哪一个java线程占用了CPU资源时,按照以下步骤进行查找: 第一步:登陆到web服务所在的liunx服务器,利用top命令获取java的cpu使用率 第二步: 如上图所示,java的进程id为'3260',接下来用top命令单独对这个进程中的所有线程作监视:top -p 3260 -H 第三步: 如上图所示,linux下,所有的

转 JVM找出占用CPU最高的线程

这两天客户这边有一台服务器一到下午3点左右就开始卡住,页面无法访问,服务器CPU占用达到300%多开始以为只是可能只是意外事件,重启一下就好,但是发现重启之后没几分钟服务器马上又反应无法访问,我就开始检查自己写的代码是不是有什么非常消耗CPU资源的逻辑,但是找了一段时间之后还是一无所获,不过马上反应的就是先把最新提交发布的代码还原到上一个版本.但是没过多久还是反应服务器开始又开始无法访问了.于是就第一步: 通过 top命令查找到这个消耗CPU的进程号PID 8958 top第二步:使用 top

[java] 找出字符串中出现最多的字符和出现的次数

逛园子看到一童鞋做的华为上机题目,写来好长的代码,懒得看,感觉不可能这么难,于是动手敲了下. import java.util.Scanner; public class StringTest { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Scanner scanner = new Scanner(System.in); String A = s

php-cgi进程占用cpu资源过大原因分析及解决

一,开启日志记录,为以后排查做准备 1.1 开启php-fpm.conf的错误日志和慢执行日志和常规日志, 采样一个小时,就可以根据这些日志的内容进行分析问题error_log = /tmp/error.log //错误日志access.log = /tmp/access.$pool.log //常规日志,记录每次访问时间,记录不同参数,以防止恶意攻击,后面会详细解析access.format = "%R – %u %t \"%m %r%Q%q\" %s %f %{mili}

使用top工具,找出消耗CPU 较多的进程

1.使用top工具,找出消耗CPU 较多的进程 [[email protected] ~]$ top top - 10:48:27 up 23:15,  4 users,  load average: 1.09, 0.43, 0.15 Tasks: 161 total,   3 running, 158 sleeping,   0 stopped,   0 zombie Cpu(s): 74.3%us, 23.7%sy,  0.0%ni,  0.0%id,  2.0%wa,  0.0%hi, 

Java 找出四位数的全部吸血鬼数字 基础代码实例

/** * 找出四位数的全部吸血鬼数字 * 吸血鬼数字是指位数为偶数的数字,能够由一对数字相乘而得到,而这对数字各包括乘积的一半位数的数字,当中从最初的数字中选取的数字能够随意排序. * 以两个0结尾的数字是不同意的. *   比例如以下列数字都是吸血鬼数字 1260=21*60 1827=21*87 2187=27*81 ... * 比較笨的低效率的做法: 遍历全部四位数, 每生成一个四位数的时候, *         在双重循环遍历两位数,在两位数的内层循环中推断是否与最外层循环的四位数相等

找出java代码中占用cpu过多问题

当有java进程占用过多CPU时,可能是逻辑出现的问题.如何排查问题所在呢? 1. 使用top工具列出所有进程,shitf + p 列出CPU占用率较高进程 2. 找到问题进程号,使用top -H -p pid列出进程的所有线程 3. 然后shift + p 按照CPU使用率排序 4. 找出问题进程号,使用python打印出其16进制值,print("0x" % ppid),比如是:76a3 5. jstack pid > t.dat 记录线程堆栈,vi 打开找到76a3的线程号

找出占用高的进程

1.找出僵尸进程ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]' -A 参数列出所有进程 -o 自定义输出字段,我们设定显示字段为stat(状态),ppid(父进程pid),pid(进程pid),cmd(命令行)这四个参数因为状态为 z 或者 Z的进程为僵尸进程,所以我们使用grep 抓取stat 状态为zZ进程: 运行后,在此运行ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]' 来确认是否将僵尸进程杀死:如果kill

Windows找出占用端口的进程

第一步:找出监听指定端口的进程号: C:\> netstat -ao | findstr 443  TCP    0.0.0.0:443            Sean-NotePC:0          LISTENING       12776 最后一个就是进程号,12776. 第二步:找出进程号对应的进程: C:\> tasklist /fi "PID eq 3040" 映像名称 PID 会话名 会话# 内存使用 ========================= =