jstack查找应用瓶颈

1,首先在服务器输入top命令,找出消耗cpu最多的进程的pid


可以看到pid为5563消耗cpu资源最多

2,输入命令top -Hp 5563查看这个进程下各个线程消耗资源情况


3,然后输入jstack 5563 > dump.txt导出该java进程的堆栈情况,可以多导出几个文件对比

4,将线程的PID5568,5567,5565,5566转成16进制,window自带的计算机就很好用


转成16进制分别是15bd,15be,15bf,15c0

5,打开dump.txt,刚才转成16进制的值便是线程的nid,搜索15bd,15be,15bf,15c0


我这边消耗资源多的线程都是gc,看来是我的jvm的堆内存设小了,囧

顺便分析下在线查看jstack文件的网站:https://jstack.review/#tda_1_dump

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容