@[TOC]
确定是问题类型(CPU型/内存型问题)
- 观察 tomcat 日志有无明显异常,如 OOM 报错则可以直接判断为内存型tomcat问题。
- 通过
top
/df -h
/ps
/free
命令查看系统资源占用情况。
问题分析
CPU 型
一般表现为:存在计算量大、复杂的算法 / 存在死循环代码
- 通过 top 命令查看占用 CPU 高的进程。 top -p <pid> 可以查出某个进程的资源占用情况。
- 通过 top 查看某个进程中的所有线程占用情况
top -p <pid> H
- 通过 jstack 定位问题。
内存型
- 通过日志直接定位
- 采集 OOM 数据:
JvmOptions="-XX:+HeapDumpOnOutOfMemoryError" JvmOptions="-XX:HeapDumpPath=$(COREMAIL_HOME)/logs/tomcat-heapdump.bin"
问题解决
CPU 型
- 一般能够找到对应代码问题,优化代码。
- 提高硬件设备。
内存型
- 找到代码的地方、优化。
- 寻找能够优化的配置,如 PermGen(不过 JAVA 8之后就废弃了持久代),增加 jvm 内存。
- 提高硬件设备