博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux下java进程CPU占用率高分析方法
阅读量:4988 次
发布时间:2019-06-12

本文共 2030 字,大约阅读时间需要 6 分钟。

在工作当中,肯定会遇到由代码所导致的高CPU耗用以及内存溢出的情况。这种情况发生时,我们怎么去找出原因并解决。

一般解决方法是通过命令找出消耗资源高的线程id,利用strace命令查看该线程所有系统调用

1. 通过找到可疑进程PID

top - 09:37:18 up 70 days, 16:29,  2 users,  load average: 1.13, 1.04, 0.97Tasks: 105 total,   1 running, 104 sleeping,   0 stopped,   0 zombieCpu(s):  1.0%us,  4.9%sy,  0.0%ni, 93.6%id,  0.0%wa,  0.0%hi,  0.0%si,  0.5%stMem:   2067816k total,  1756680k used,   311136k free,   236340k buffersSwap:   524284k total,   255508k used,   268776k free,   277040k cached  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND24138 apache    20   0 1273m 384m 3668 S 103.3 19.0   1232:39 java 3359 root      39  19  2704   36    0 S  0.3  0.0   4:39.34 gam_server 6696 root      20   0 34148 1604  244 S  0.3  0.1   5:06.63 httpd19254 root      20   0  785m 221m 3176 S  0.3 11.0   9:04.36 java    1 root      20   0  2224   28    0 S  0.0  0.0   1:22.46 init    2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd    3 root      20   0     0    0    0 S  0.0  0.0   0:33.42 ksoftirqd/0    5 root      20   0     0    0    0 S  0.0  0.0   0:00.03 kworker/u:0

 

从上面命令中可以看出java进程CPU利用率一直保持100%,稳居不下,找到PID 24138

2. 找出消耗资源最高的线程

top -H -p  24138 可以不用第一步,直接执行命令 top -H ,就可以查看到消耗资源最高的线程

top - 09:49:49 up 70 days, 16:41,  2 users,  load average: 1.01, 1.04, 1.00Tasks:  72 total,   1 running,  71 sleeping,   0 stopped,   0 zombieCpu(s):  0.6%us,  1.3%sy,  0.0%ni, 97.7%id,  0.1%wa,  0.0%hi,  0.0%si,  0.2%stMem:   2067816k total,  1760840k used,   306976k free,   236744k buffersSwap:   524284k total,   253344k used,   270940k free,   279092k cached  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND24167 apache    20   0 1273m 384m 3688 R 99.1 19.0   1169:43 java24152 apache    20   0 1273m 384m 3688 S  2.0 19.0   0:28.58 java24188 apache    20   0 1273m 384m 3688 S  2.0 19.0   4:56.69 java24138 apache    20   0 1273m 384m 3688 S  0.0 19.0   0:00.00 java

3. 查看这个线程所有系统调用

strace -p 24167

 

 

通过这3步基本可以找出什么原因导致java进程占用那么高CPU资源。

转自:

 

转载于:https://www.cnblogs.com/lj2007331/p/3277067.html

你可能感兴趣的文章
洛谷P5205 【模板】多项式开根(FFT)
查看>>
CentOS 7.X 设置系统时间
查看>>
ie6 div+css
查看>>
Hbase 源码研究
查看>>
python IsWindowEnabled遍历windows的所有窗口并输出窗口标题
查看>>
java面向对象三大特性:封装、继承、多态
查看>>
Oracle sql优化
查看>>
sweetalert 快速显示两个提示, 第二个显示不出的问题
查看>>
Redis 键(key)
查看>>
granger Z-score问题
查看>>
mybatis系列-07-输出映射
查看>>
将本地项目和远程git仓库相连接
查看>>
cocos3.12预编译android报错RuntimeJsImpl.cpp
查看>>
未解决的题-幂函数的奇偶性
查看>>
wc移植sae笔记
查看>>
<welcome-file-list>标签作用,怎样使用
查看>>
栈和队列
查看>>
db2 数据库配置HADR+TSA添加集群节点
查看>>
event Flow
查看>>
[Linux]Ubuntu设置时区和更新时间
查看>>