Troubleshooting high CPU usage in java applications

1.find the jvm process

    ps aux | grep java

    tomcat  26551  128   30.9  3946348  1215360  ?  S1  13:43  26:21  /usr/java/latest

2. generate thread dump of the java main thread found in step 1

    JVM main thread = Linux process,other java threads = Lightweight process(LWP)

    jstack 26551 > threaddump.log

3. find suspect lightweight processes(LWPS) with high cpu usage

    top -H

    第一行:整体运行情况

    top - 13:59:28  up 29days,11:16, 1 user, load average:5.15, 4.75, 3.38

    13:59:28:当前系统时间(在这期间没有重启过)

    up 29days:系统已经运行的时间

    1 user: 当前登录用户的数量

    load average:5.15, 4.75, 3.38:1分钟,5分钟、15分钟系统平均负载

    load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。        如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

     第二行:任务

    Task:512 total, 8 running,504 sleeping 0 stopped, 0 zombie

    512 total:共147个任务(进程)

    8 running:有8个任务(进程)正在运行

    504 sleeping:有145个任务(进程)正在睡眠

    0 stopped:有0个任务(进程)已经停止

    0 zombie:有0个僵尸任务(进程)

    第三、四行:CPU

    Cpu0 84.9%us, 9.4%sy, 0.0%ni, 3.7%id, 0.7%wa,0.0%hi, 1.3%si, 0.0%st

    Cpu1 84.7%us, 8.0%sy, 0.0%ni, 5.0%id, 0.7%wa,0.0%hi, 1.7%si, 0.0%st

    us:运行(未调整优先级的)用户进程所占的cpu时间(百分比)

    sy:运行系统内核进程所占的cpu时间(百分比)

    ni:运行用户进程(已经调整优先级的)进程所占的CPU时间(百分比)

        负值表示高优先级,正值表示低优先级

    id:空闲进程所占的cpu时间(百分比)

    wa:用于等待IO完成所占的cpu时间(百分比)

    hi: 硬件中断

    si: 软件中断

    st:实时

    第五行:内存

    Mem: 3924512K total, 378434k Ok used, 140172k free, 148876k bufferes

    物理内存:全部内存 已使用内存  空闲内存 缓冲内存

    第六行:swap交换分区

    交换区内存:交换区总量使用的交换区总量空闲交换区总量缓冲的交换区总量

    如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free + 第四行的

    buffers + 第五行的cached,按这个公式此台服务器的可用内存:

    530668+79236+4231276 = 4.7GB。

    对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在     

   不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。

   其他行的LWPS数据

   PID     USER   PR   NI  VIRT     RES  SHR     S   %CPU  %MEM  TIME+   command

   26605 tomcat  20   0  3853m  1.1g   12m      R    32.2       29.8     3:10.85

    PID:进程ID

    USER: 进程所有者的实际用户名

    PR:进程的调度优先级。这个字段的一些值是rt,这意味着这些进程运行在实时态

    NI:进程的nice值(优先级),越小的值意味着越高的优先级

    VIRT:进程使用的虚拟内存

    RES:驻留内存大小。驻留内存时任务使用的非交换物理内存大小

    SHR:进程使用的共享内存

    S:进程的状态

    D - 不可中断的睡眠态

    R - 运行态

    S - 睡眠态

    T - 被跟踪或已停止

    Z - 僵尸态

    CPU:从上一次更新时到现在任务所使用的CPU时间百分比

    MEM:进程使用的可用物理内存百分比

    TIME:任务启动后到现在所使用的全部CPU时间,精确到百分之一秒。

    COMMAND:运行进程所使用的命令

     It can be observed there are tow LWPs using 32% and 14% of the cpu

     where the rest stays around the the same percentage

4.conver LWP IDS from decimal to hexadecimal for pids with high cpu usage

Decimal hexadecimal(将十进制转十六进制)

26605      67ED

26602      67EA

5.open threaddump from step 2 and locate hex value 0x67ed and 0x67ea

   

6.troubleshoot

From previous stack trace examples,seems high CPU usage is related to log4j async appender,

In this case very likely involving PCIPatternLayout.format() method.

7.另外可考虑客户端请求书是否过大

监控网络客户连接数:

netstat -n | grep tcp | grep 侦听端口 | wc -l

引用资料:

http://tech.asimio.net/2016/02/11/Troubleshoot-high-CPU-usage-in-Java-applications.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容