栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

程序侦探马之追查Java程序占用cpu使用率高问题

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

程序侦探马之追查Java程序占用cpu使用率高问题


最近在Linux服务器上部署java程序,头几天java程序还是在正常运作,然后就开始发现程序在cpu使用率上非常高,所以,程序侦探马对此问题展开追查。


追查过程:

1.查看资源占用情况
# 使用top命令进行查看各个进程的资源占用情况,发现果然是java程序占用cpu使用率最高
# 根据发现,占用CPU使用率高的java程序的pid为:26357
top

2.查看该进程的线程情况
# 根据该命令可以查看到该进程的每一条线程的情况
# 通过以上线程切片,可以发现一条线程的cpu使用率和运行时间的状况
# 可以发现 耗时00:50:28,cpu使用率为99.9%的线程tid为26541
ps -mp 26357 -o THREAD,tid,time

3.查看该线程的状况
# 获取到tid后需要将tid转换成16进制,方便在jvm堆栈中查找
printf "%xn" 26541

# 可以获得结果为67ad
# 通过jstack命令来查看该线程当前的内存状态 【jstack pid|grep 转换为16进制的tid -A 30】
jstack 26357|grep 67ad -A 30

# 可以发现cpu使用率高的原因:
# 1.程序死循环
# 2.IO读写太高

4.查看进程中的各个线程状况的方法二:
# 1.首先使用top命令查看各进程状况
top

# 2.然后根据进程的pid查看该进程的状况
top -p 26357

# 3.然后将键盘切换为大写,点击H,就可以查看到各线程的状况
# 可以根据各线程的tid进行查看该线程当前的内存状态 【返回执行第3步】
4.1 top

4.2 top -p 26356

4.3点击大写H

4.4 16进制转换

4.5 查看线程当前的内存状态

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/271298.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号