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

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

    java linux cpu占用过高
  3. ps H -eo pid,tid,%cpu | grep xxx(进程id)筛选

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

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

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

    java linux cpu占用过高
    上图示例为死循环代码。 实际项目中可能是其他代码。

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

相关文章: