java linux cpu占用过高

  1. top 查看各项使用情况(只能看到进程id)

  2. ps H -eo pid,tid,%cpu 命令查看 进程id 线程id cpu占用情况(找到线程占用过高的进程id)

  3. ps H -eo pid,tid,%cpu | grep xxx(进程id)筛选

    ps H -eo pid,tid,%cpu | grep 32665
  4. jstack xxx(进程id) 查看进程的所有线程 


    打印的是每个线程的信息,将线程id(上面命令找到的tid 32665)由十进制转换为十六进制,找到nid=0x7f99(32665转换得0x7f99)的线程


    上图提示:线程thread1 正在运行,且问题位置为 Demo1_16.java 的第8行,找到位置就可以解决问题了。


    上图示例为死循环代码。 实际项目中可能是其他代码。

     
  5. 如果是gc问题 可以查看 传送门
  6. 如果是死锁导致结果一直不返回(死锁问题)
    使用     jstack 进程id         命令查看

其他参考文章

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值