• 用Jstack跟踪Cpu占用率的Java线程(转)


    以下方法在centOS下执行通过:
    1.先定位占用cpu高的进程

    top

    2.使用以下命令

    ps p 14766 -L -o pcpu,pid,tid,time,tname,stat,psr | sort -n -k1 -r

    其中14766是刚才1中cpu占用率高的进程pid

    3.2.4 32525 32537 01:58:41 ?        Sl     6 
    0.8 32525  1771 00:43:12 ?        Sl     0 
    0.8 32525  1769 00:39:46 ?        Sl     0 
    0.7 32525 12324 00:33:36 ?        Sl     0 
    0.5 32525  1772 00:27:50 ?        Sl     0 
    0.5 32525  1768 00:25:45 ?        Sl     0 
    0.4 32525 30760 00:19:13 ?        Sl     0 
    0.4 32525  1773 00:22:36 ?        Sl     0 
    0.4 32525  1770 00:20:25 ?        Sl     0 
    0.3 32525 32385 00:00:10 ?        Sl     0 
    0.1 32525 31668 00:00:03 ?        Sl     0 
    0.1 32525 31667 00:00:03 ?        Sl     0 
    0.1 32525  1790 00:07:10 ?        Sl     1

    其中第3个结果就是此进程中有问题的线程nid

    4.通过jstack命令dump出堆栈

    "AppController_ThreadPool_L2_Pool Thread" daemon prio=10 tid=0x0000000051c2b000 nid=0x7bb3 in Object.wait() [0x000000005e3c5000] 
       java.lang.Thread.State: TIMED_WAITING (on object monitor) 
            at java.lang.Object.wait(Native Method) 
            at org.company.threadpool.ThreadPoolImpl$PoolThread.run(ThreadPoolImpl.java:142) 
            - locked <0x00002aaca30341a8> (a org.company.threadpool.ThreadPoolImpl$PoolThread)

    其中的nid就是线程的编码,只不过是经过了16进制的转换。

    即十进制的31776对应的十六进制)0x7bb3,定位到线程后一切好办。 

    http://www.blogjava.net/diggbag/articles/jstack.html

  • 相关阅读:
    C Primer Plus_第三章_数据和C_复习题与编程练习
    如何确定你的编程环境下不同数据类型数据的储值范围
    vs2010调试程序出现“Cannot find or open the PDB file”
    C Primer Plus_第二章_C语言概述_复习题与编程练习
    C Primer Plus_第一章_概览_复习题与编程练习
    [au3]复制选择性粘贴文本到excel
    subversion
    Centos7.0安装配置PHP7.0
    C#的UDP服务器
    CentOS7搭建NAS,包括NFS、ISCSI
  • 原文地址:https://www.cnblogs.com/softidea/p/5266622.html
Copyright © 2020-2023  润新知