我们都知道top
命令可以查看linux的系统状况,是常用的性能分析工具,能够实时显示系统中各个进程的资源占用情况。
top
对CPU时间片的分类如下:
- us:用户进程空间中未改变过优先级的进程占用CPU百分比
- sy:内核空间占用CPU百分比
- ni:用户进程空间内改变过优先级的进程占用CPU百分比
- id:空闲时间百分比
- wa:空闲&等待I/O的时间百分比
- hi:硬中断时间百分比
- si:软中断时间百分比
- st:虚拟化时被其余VM窃取时间百分比
这8类分片中,除wa和id外,其余分片CPU都处于工作态。
因此判断用户进程占用CPU的高低,可以通过查看us
、sy
、si
来判断。
如果占用CPU较高的是Java程序,我们该如何判断是Java程序中的哪个线程导致的问题呢?
方法如下:
top 命令找出应用 pid-app
top -Hp <pid-app> 命令找出线程 pid-thread
printf '%x\n' <pid-thread> 命令将线程 pid 转换成 16 进制 pid-thread-hex
jstack <pid-app> | grep <pid-thread-hex> 命令查看线程信息
抓到线程信息之后,就是仔细分析的时候了,这个时候基本就真相大明了,这里也就不多BB了。
如果提示:
[root@root ~]# jstack 7028 | grep 1ba0
7028: Unable to open socket file: target process not responding or HotSpot VM not loaded
The -F option can be used when the target process is not responding
原因:jstack
需要使用与进程一致的用户才能执行,切换用户再次执行即可。
除非注明,否则均为李锋镝的博客原创文章,转载必须以链接形式标明本文链接