一、通过进程和线程
首先,需要知道哪个进程占用CPU比较高;其次,需要知道占用CPU高的那个进程中的哪些线程占用CPU比较高;然后,需要知道这些线程的stack trace。
二、通过堆栈和应用日志
找出了CPU占用高的线程号和其stack trace并再结合应用日志基本上就可以找到问题根源。接下来,将介绍相应的工具来找到这些问题的答案。
四、通过工具
4.1、top和pgrep
通过top和pgrep来查看系统中Java进程的CPU占用情况。命令如下:
top -p `pgrep -d , java`
其中pgrep是显示系统中java应用的进程号,top -p是只显示这些进程的信息。记录下CPU占用率最高的那个进程号。
4.2、通过top来查看进程中CPU占用最高的那些线程,命令为:
top -Hp X<

本文介绍了如何在面试中回答如何找到Java应用CPU使用率飙升的原因。通过进程和线程监控,结合堆栈和应用日志,利用top、pgrep、jstack等工具进行排查。重点关注垃圾回收线程和业务处理线程,分析GC日志,查找可能的死循环或内存溢出问题。
最低0.47元/天 解锁文章
172万+

被折叠的 条评论
为什么被折叠?



