tomcat 故障/假死排查思路(未完)

1,248 阅读1分钟

确定是问题类型(CPU型/内存型问题)

  1. 观察 tomcat 日志有无明显异常,如 OOM 报错则可以直接判断为内存型tomcat问题。
  2. 通过 top / df -h / ps / free 命令查看系统资源占用情况。

问题分析

CPU 型

一般表现为:存在计算量大、复杂的算法 / 存在死循环代码

  1. 通过 top 命令查看占用 CPU 高的进程。 top -p 可以查出某个进程的资源占用情况。
  2. 通过 top 查看某个进程中的所有线程占用情况
    top -p <pid> H
    
  3. 通过 jstack 定位问题。

内存型

  1. 通过日志直接定位
  2. 采集 OOM 数据:
    JvmOptions="-XX:+HeapDumpOnOutOfMemoryError"
    JvmOptions="-XX:HeapDumpPath=$(COREMAIL_HOME)/logs/tomcat-heapdump.bin"
    

问题解决

CPU 型

  1. 一般能够找到对应代码问题,优化代码。
  2. 提高硬件设备。

内存型

  1. 找到代码的地方、优化。
  2. 寻找能够优化的配置,如 PermGen(不过 JAVA 8之后就废弃了持久代),增加 jvm 内存。
  3. 提高硬件设备