java应用占用内存和CPU分析
起源与动机
在生产中突然发现某java应用程序的cpu或者内存占比较高,除了利用JDK自带的jconsole与jvisualVM以外,可以在linux下用命令实现查看。
#分析步骤
-
找到目标程序;
1.如果知道应用程序的名称
1)ps -ef | grep “程序名称”;//查到PID
2.不清楚应用程序的名称
2)top //查看所有进程,默认按cpu使用量排序,可通过"shift+>"或者“shirt+<”更换排序方式 -
通过第一步确定的pid,查看进程id
1.排查cpu占比较高
1)ps -mp pid -o THREAD,tid,time,rss,size,%mem //查看该进程下的所有线程cpu占用情况
2)printf “%x\n” tid //找到占用cpu最高的线程id,将其转为16进制
3)jstack pid |grep tid -A 30 //打印线程的堆栈信息
4)jstack pid > stack.log //或者直接将进程的堆栈信息输出到文件
2.排查内存占用较高
1) jmap -histo:live [pid] //然后分析具体的对象数目和占用内存大小,从而定位代码。
jmap -dump:live,format=b,file=xxx.xxx [pid] //然后利用MAT工具分析是否存在内存泄漏等等。
2)利用MAT工具去分析dump出来的文件。
图片:
参考链接
[1]: https://blog.youkuaiyun.com/li12412414/article/details/81366478
[2]: https://www.cnblogs.com/edgedance/p/7044753.html
[3]: https://blog.youkuaiyun.com/puhaiyang/article/details/78663942
[4]: https://blog.youkuaiyun.com/jin_kwok/article/details/80326088