• 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 二进制的号
  • 相关阅读:
    HDU 1017—A Mathematical Curiosity
    N !
    L
    J
    Danganronpa
    A water problem
    hdu 5461 Largest Point
    India and China Origins hdu 5652 (BFS+二分)
    D (多校训练三) poj1919 (二分)
    Discovering Gold lightoj 1030 (dp+期望)
  • 原文地址:https://www.cnblogs.com/wghzzu/p/8682309.html
Copyright © 2020-2023  润新知