Java应用线上CPU飙高

  说明:曾经遇到过的一个线上实际问题,Demo是经过加工刻意重现,线上调试问题已经开发和运维人员的基本技能,在此备忘记录。


1、找出CPU占用较高的PID


  通过top命令,查找出占用CPU较高的PID:3639
pid.png


2、找出PID对应的TID


  命令:ps -mp 3639 -o THREAD,tid,time | sort –rn 这里可以看出查到的TID对应的是***3673***。
tid.png


3、将TID转成16进制


  命令:printf “%x\n” 3673 转成十六进制为***e59***。


4、通过jstack命令查出该线程栈信息


  命令:jstack 3546|grep e59 -A 100 前面数字是PID,后面红色数据是十六进制的TID。这里也可以通过***jstack pid >/home/stack.log***导出日志。
stack.png
  可以看上面蓝色部分很清晰的标出了可能有问题的代码位置,可以对比源码,我在20行的位置上面用个死循环导致的。
res.png
  提示:若不能及时定位问题,可以通过jmap将JVM的dump日志导出,线下分析用。若jstack、jmap不能使用,可以配置一下环境变量或者切到jre的bin目录下使用。


更多可以关注

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java应用程序CPU过高内存不高的原因有以下几个可能: 1. 程序中存在大量的计算密集型操作或循环。Java是一种高级编程语言,它的执行速度相对较慢。如果应用程序中存在很多循环或者大量的复杂计算,就容易导致CPU占用率高。 2. 程序中存在死循环或者无限递归调用。死循环或者无限递归调用会导致程序陷入无限循环中,CPU会一直占用在该循环中,从而导致CPU占用率过高,而内存占用率不高。 3. 使用了不合理或者低效的算法。如果应用程序中使用了不合理或者低效的算法,就会导致CPU占用率高。这种情况下,可以尝试使用更加高效的算法或者数据结构来优化程序的性能。 4. 多线程使用不当。Java是支持多线程编程的语言,如果在程序中使用了大量的线程,并且这些线程之间存在竞争条件或者同步问题,就可能导致CPU占用率高。在使用多线程时,需要合理地进行线程管理和资源分配,避免出现资源争用导致的CPU过高问题。 综上所述,Java应用程序CPU过高而内存不高的原因可能是程序中存在大量的计算密集型操作、死循环或者无限递归调用、使用了不合理或者低效的算法,或者多线程使用不当等。在解决这个问题时,可以尝试优化程序的算法、检查并修正死循环或者无限递归调用的问题、合理利用多线程等方式来降低CPU的占用率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值