良许Linux教程网 干货合集 Linux下排查占用CPU很高Java程序

Linux下排查占用CPU很高Java程序

Linux下如何排查占用CPU很高Java程序占用?本篇文章将使用jstack为大家演示一下Linux下排查Java程序占用CPU很高具体方法,jstack是java虚拟机自带的一种堆栈跟踪工具。jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息。

src=http___jsz.cloud_assets_images_banner.jpg&refer=http___jsz

故意设置了一个CPU占用很高的场景:

img

排查问题,步骤:

\1. ps -mp 【替换为进程ID PID】 -o THREAD,tid,time

img

发现线程6322、6323占用CPU很高,时间也很长。

\2. printf “%x” 【线程ID TID】

img

把TID转换为16进制。

\3. jstack 【进程ID PID】 | grep 【线程ID十六进制】 -A 10 -B 10

img

利用jstack工具,查看前后10行,发现问题所在!

代码中故意设置:

img

\4. 重复2、3,查看另一个线程。

附录:要访问自己的Virtual Box,网络设置要调整为:

img

以上就是良许教程网为各位朋友分享的Linux系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你!

137e00002230ad9f26e78-265x300

本文由 良许Linux教程网 发布,可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
良许

作者: 良许

良许,世界500强企业Linux开发工程师,公众号【良许Linux】的作者,全网拥有超30W粉丝。个人标签:创业者,CSDN学院讲师,副业达人,流量玩家,摄影爱好者。
上一篇
下一篇

发表评论

联系我们

联系我们

公众号:良许Linux

在线咨询: QQ交谈

邮箱: yychuyu@163.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部