• CPU占用率高分析方法步骤[转载]


    由于涉及到私有代码,所有图片都隐去

    1、执行TOP命令,确认CPU占用较高的进程PID

    根据top命令,发现PID为8691的Java进程占用CPU高达3858%,出现故障

    2、确认该进程中CPU占用率高的线程

    找到该进程后,如何定位具体线程或代码呢?首先显示线程列表,并按照CPU占用高的线程排序。执行如下命令:

    ps -mp 8691 -o THREAD,tid,time | sort –rn

    从该列表中可以看出TIME列,所有线程占用时间都比较高,达到了3个小时以上。可以选择其中一个线程(TID)进行分析

    3、将线程ID转换为16进制格式

    执行命令:printf "%x " 8729

    4、查看线程的堆栈信息

    执行命令:jstack PID |grep 线程ID的16进制步骤3的结果 -A 30

    黄色部分需要替换为进程ID和线程ID的16进制,如下图:

    5、查看堆栈信息

    根据步骤4 的堆栈信息,确认问题。如下:

    "20150807#174500#1500#XXXX#1434545713195[35/1144]" prio=10 tid=0x00000000008ba000 nid=0x3b5e waiting for monitor entry [0x00007f5b7cac2000]

       java.lang.Thread.State: BLOCKED (on object monitor)

             at com.xxx.xxx.xxxx.xxxx()

     

    从上面的堆栈信息中可以看出哪段代码有问题。进而再分析代码。

  • 相关阅读:
    3.7号一周学习
    3.6号
    人月神话01
    课堂测试之全国疫情统计可视化地图第一阶段完成
    课堂测试之全国疫情统计可视化地图
    2.25号课堂作业
    2.29一周学习
    软件工程第二周开课博客
    2.25号课堂测试
    Mysql+Mycat实现数据库主从同步与读写分离
  • 原文地址:https://www.cnblogs.com/jiyuqi/p/4723583.html
Copyright © 2020-2023  润新知