假设tomcat进程PID为16818
确认是不是内存本身分配过小:jmap -heap 16818
找到最耗内存的对象:jmap -histo 16818 (带上:live则表示先进行一次FGC再统计,如jmap -histo:live 16818)
导出内存转储快照:jmap -dump:live,format=b,file=heap.bin 16818 (使用Eclipse mat分析)
统计进程打开的句柄数:ls /proc/16818/fd |wc -l
统计进程打开的线程数:ls /proc/16818/task |wc -l
参考文章:
Linux下分析Java程序内存(pmap、jmap、jstat)
内存泄露排查工具到底哪家强?
关于Java Tomcat 内存溢出排查心得分享