linux上Java应用的CPU占用率高的问题排查

  • top命令找出有问题Java进程及线程id:
  • 开启线程显示模式(top -c)
    按CPU使用率排序(top缺省是按CPU使用降序,已经合要求;打开top后按P可以显式指定按CPU使用降序)
  • 记下Java进程id及其CPU高的线程id
  • 用进程id作为参数,jstack有问题的Java进程
  • 手动转换线程id成十六进制(可以用printf %x 1234)
  • 查找十六进制的线程id(可以用vim的查找功能/0x1234,或是grep 0x1234 -A 20)
  • 查看对应的线程栈,以分析问题

1.查看服务器cpu占用率最高的应用 :

指定应用名称查看CPU  两种方式都行
top -c    
指定应用名称查看CPU  两种方式都行
top -c|grep agent
ps aux|grep agent  
指定应用名称查看CPU  两种方式都行
top -p 24455  

在这里插入图片描述

2.经过上一步查询出CPU占用最高的"进程"pid为15256

查询出15256进程的所有"线程"
top  -H -p  15256			

在这里插入图片描述
线程15318 CUP的占用率最高,把这个pid转成16进制(后面会用到)。
3bd6 就是转换完的16进制pid

[app01@gcdc-wxtest01 ~]$ printf %x 15318
3bd6[app01@gcdc-wxtest01 ~]$ 

3,

jstack 15256 > thread.txt         导出当前"线程(15256)"所在"进程(15318)"的日志文件

4,找到导出的thread.txt 文件 这里都是线程的日志,我们查到3bd6。查看对应的线程栈,以分析问题
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值